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INTRODU^AO 


O objetivo do presente livro e possibilitar ao leitor programar em 
linguagem de maquina. Para isto, parte-se da supos^ao de que ele ja 
consegue escrever sens programas em BASIC. As observances e 
instrunoes que sao aqui fornecidas supoem que seu computador possua 
um microprocessador Z80A (fabricado pela Zilog) e, em especial, que 
o ROM (a memoria escrita pelo fabricante do computador) seja 
semelhante ao do ZX-81 ou do TIMEX 1000 produzidos pela Sinclair e 
pela Timex, respectivamente. No Brasil isto indica os TKs 82-C, 83 e 
85, o CP-200 e o NE-Z8000. 

A aquisigao desta nova linguagem permitira, no presente caso, 
uma rapidez maior na execugao dos programas, assim como uma 
ocupagao menor da area onde se pode escrever (o RAM). 

A razao disto e facil de entender. Quando se escreve um programa 
em BASIC, ele tern de ser guardado e traduzido em linguagem de 
maquina, a unica que o Z80 entende. Ora, a tradugao leva um certo 
tempo para ser executada. Podendo-se programar em linguagem de 
maquina, se estara nao so utilizando uma menor area de programagao 
(nao ha necessidade de guardar as instrugpes em BASIC), como 
poupando um consideravel tempo (nao havendo necessidade de 
tradugao, o"tempo e, em media, vinte vezes menor). 
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Alem disso, a linguagem de maquina tambem possibilita uma 
protegao maior para o software que por ventura se venha a criar. 

Os capitulos devem ser lidos na sua ordem seqiiencial e o leitor so 
deve passar para o seguinte se for capaz de resolver todos os 
exercicios propostos no final de cada parte. Para soluciona-los, deve- 
se utilizar o computador. So assim o programador sera capaz de 
adquirir dormnio da linguagem de maquina. 

Todos os programas fornecidos no presente livro tern um objetivo 
pedagogico. Convem procurar modifica-los ou utiliza-los em seus 
proprios programas. 

E preciso muita paciencia. Diferentemente do que ocorre com 
BASIC, nao ha aqui um leitor de erros. Se ocorrer algum, na tela 
aparecerao as mais variadas coisas ou se perdera o controle do teclado, 
ou se deparara com ambas as situagoes. A unica maneira de contornar 
esse desastre (crash), e desligar o computador e recomegar tudo. 
Portanto, antes de rodar o programa, procura-se grava-lo, pois, caso 
suceda um crash, bastara recoloca-lo e, atraves de seu estudo, detectar 
a possivel causa do erro. Em qualquer caso, nao ha motivo para 
preocupar-se — e impossivel danificar o aparelho, mesmo quando os 
programas sao escritos em linguagem de maquina. 

Nunca e demais insistir: a simples leitura do livro nao ira 
transformar o leitor num bom programador. Apenas a pratica constan- 
te pode contribuir para torna-lo competente no uso da linguagem de 
maquina. Por conseguinte, maos a obra! 
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CAPITULOI: 

NUMEROS BINARIOS E HEXADECIMAIS 


No manual recebido juntamente com o seu computador existe um 
capitulo sobre o emprego de linguagem de maquina. Nele voce aprende 
que as rotinas nesta linguagem podem ser executadas a partir da 
utilizagao da fungao USR. Durante o texto explicaremos todas as 
consideragoes que sao feitas a respeito do uso dessa fungao. Por ora, 
queremos salientar apenas o fato de que o emprego de linguagem de 
maquina e feito atraves do uso de uma rotina que deve, de alguma 
forma, retornar ao programa em BASIC. 

Por exemplo, digite e rode o seguinte programa: 

10 POKE 18000,62 
20 POKE 18001,1 
30 POKE 18002,205 
40 POKE 18003,8 
30 POKE 18004,8 
60 POKE 18005’,24 
70 POKE 18006,249 
80 RAND USR 13000 

O que aconteceu? 

A tela ficou rapidamente ocupada com o caractere numero 1 
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(Apendice 1), dando indicagao de erro tipo 5, na linha 80. Se voce 
digitar CONT, a situagao se repetira. Em outras palavras, nao ha mais 
espago na tela. A instrugao CONT limpa a tela, mas esta fica de novo 
imediatamente repleta. , 

Mais tarde, voce entendera por que isto esta ocorrendo. Mas antes 
de continuarmos, substitua a linha 20 por 20 POKE 18001,3 e rode o 
programa. Agora, a tela esta totalmente ocupada pelo caractere 
numero 3. 

O que estamos fazendo? 

Simplesmente colocando numa serie de enderegos, de 18000 a 
18006, certos valores em decimal. O conjunto deles e traduzido em 
seqiiencias de numeros binarios (numeros da forma 0 ou 1 ), ou seja, 
num programa em linguagem de maquina. A execugao e feita atraves 
da CPU diretamente, isto e, atraves da unidade central de processa- 
mento, sem necessidade de ser traduzida pelo programa residente (o 
programa contido no ROM). No caso presente, teriamos: 

0011 1110 
0000 0001 
1100 1101 
0000 1000 
0000 1000 
0001 1000 
1111 1001 

Cada um desses digitos, um ou zero, e um digito binario, um BIT (em 
ingles binary digit). Estao divididos em seqiiencias de 8 BITs conti- 
guos, isto e, cada seqviencia constitui um BYTE. Portanto, nosso 
programa consiste de sete BYTEs. Contudo, como podemos facilmen- 
te observar, nao e muito viavel programar em numeros binarios. No 
entanto, como a CPU so interpreta este tipo de numero (criado 
fisicamente por diferenga de voltagem), e preciso saber como passar 
de decimais, utilizados nas instrugoes POKE, para binarios. 

Como fazer a conversao? 

Basta recordar que os numeros decimais, numeros de base 10, 
podem ser escritos como somatoria de potencias.de dez. Por exemplo, 
62 e igual a: 6xl0l + 2 x 10®. ' 

No caso do numero binario, numero de base 2, teremos uma somatoria 
de potencias de dois. Por exemplo, 62 em decimal e igual a 0011 1110 
em binario; ou seja, igual a: 

0 x 27 + 0 x 26 + 1 x 25 + 1 x 24 + 1 x 23 + 1 x 22 + 1 x 2l H- 0 x 2®. 

Por que estamos utilizando as potencias de dois ate a setima casa? 

A resposta e simples: o Z80A pode manipular simultaneamente ate 
8 BITs, ou seja, a palavra do Z80A tern a extensao de um BYTE. 
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Portanto, so podemos fazer POKES de valores entre 0 e 255 (valores 
entre -255 e -1 sao aceitos, contudo, antes de serem manipulados, eles 
sao somados a 256). 255 tern a seguinte representaqao binaria: 

BIT 7 6 5 4 3 2 1 0 

I I I II I II 

11111111 

O BIT 7 e chamado de BIT mais significativo (MSB), enquanto o BIT 0 
e o menos significativo (LSB). 

Entretanto, como se pode notar, estamos separando um BYTE em 
dois conjuntos de quatro BITs. Qual a razao disto? 

A resposta mais uma vez e bastante simples. Como nao podemos 
trabalhar com digitos binarios (a possibilidade de cometermos um erro 
e muito grande, aliada a dificuldade em detecta-lo posteriormente), a 
mente' humana necessita de um tipo de numero que esteja mais de 
acordo com a sua natureza e que seja facilmente convertido em binario 
e vice-versa. Para isto existem os numeros hexadecimais. 

Eles sao numeros da forma 0, 1, 2, 3, 4, 5, 6 , 7, 8 ,9, A, B, C, D, E 
e F. Portanto, coincidem com os decimais ate a representagao do 
numero 9. A partir dai, de 10 a 15, sao representados pelas letras A, B, 
C, D, E e F, respectivamente. A semelhanga dos numeros vistos ate 
agora, eles tambem podem ser expressos como uma somatoria de 
potencia; neste caso, potencias de dezesseis (numeros de base 
dezesseis). 

Por exemplo, 62 em decimal e igual a 3E em hexadecimal, isto e, 
3E = 0 X 163 + |X 162 + 3X 16l + E X 16®. 

Procure entender como chegamos a esse numero. Partimos do fate 
de que 3 multiplicado por 16 e igual a 48; para chegarmos a 62, faltam 
14. A representa^ao hexadecimal de 14 e E. Logo, 62 em HEX 
(hexadecimal) e representado por 003E ou simplesmente 3E. O fato de 
antepormos dois zeros a frente de 3E esta ligado ao uso que faremos 
desses numeros no decorrer desta explanagao. Como o Z 8 ©A utiliza 
palavras de oito BITs, ele pode referir-se diretamente a endere^os de 
ate 16 BITs, ou seja, a 65536 localidades distintas. Em HEX isto indica 
desde o endere^o 0000H ate FFFF, onde FFFF e igual a 65535 em 
decimal. O primeiro par de numeros constitui o BYTE mais significati¬ 
vo (abreviado por HI), enquanto o segundo e o menos significativo 
(LO). Em outros termos, palavras de 16 BITs sao tratadas como se 
fossem duas palavras de 8 BITs cada uma. 

A rela^ao entre numeros binarios e hexadecimais e bastante 
simples. Procure justificar a seguinte tabela. 
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BINARIO 

HEXADECIMAL 

0000 0000 

00 

0000 0001 

01 

0000 0010 

02 

0000 0011 

03 

0000 0100 

04 

0000 0101 

05 

0000 0110 

06 

0000 0111 

07 

0000 1000 

08 

0000 1001 

09 

0000 1010 

0 A 

0000 1011 

0 B 

0000 1100 

0 C 

0000 1101 

0 D 

0000 1110 

0 E 

0000 1111 

0 F 


Para encontrar o binario equivalente a 3 E em hexadecimal, basta 
consultar a tabela e teremos 0011 1110 . Em outras palavras, para cada 
grupo de quatro digitos binarios em seqiiencia, colocamos um digito 
em HEX; e vice-versa: para cada digito em HEX, colocamos uma 
seqiiencia de quatro digitos em binario. 

Tambem e possivel programar o seu computador para que ele fa9a 
essas conversoes. Digite o seguinte programa: 


:i. PRINT TAB i; "DEC”»TAB 8 ? "HEX" 
3 DI Pi H< 2 >. 

10 DIM H$<2> 

1. j P (.1K !•• -- tii i U •...' 3 
2 ki I... E1 N -*• P 


2 5 L E T H < :i.) * IN T < N /1 6) 

30 LET N~N-Hi :i.) *16 

35 LET H(2 > ™N 

48 FOR A~:l. TO 2 

45 LE I H$ (A .> ~-CHK$ \ H (A ) '+23 ) 

50 NEXT A 

35 PRINT TAB 1?F?TAB 9?H$ 

60 NEXT F 


Ele converte numeros decimiis em hexadecimais no intervalo 
compreendido entre 0 e 255 . Voce encontra a tabela gerada por este 
programa no Apendice 2 . Ela sera de grande utilidade no decorrer da 
explanagao. 
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Agora tente 0 seguinte programa: 

10 DIM 1-1$ (4 ) 

.1.5 INPUT H$ 

20 LET D™0 
25 FOR 1*1 TO. 4 

30 IF CODE B$U> <28 OP. CODE H$ 
(I) > 43 THEN GOTO 13 
3 5 I... E T D :::: D +16 * w ( 4 •••• .1. ) * (C 0 D E H $ f 1) 
40 NEXT I 
43 PRINT D 
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Ele converte numeros em hexadecimal (no intervalo compreendi¬ 
do entre 0000 H a FFFF) em digitos decimais. 

Finalmente digite este programa: 


10 INPUT X 

20 FOR N~7 TO 0 STEP -1 
30 LET D=-2**N 

40 PRINT CHR$ (28+INT <X/D)>? 

50 LET X«X.INT <X/D)*D 

60 NEXT N 


Ele converte numeros decimais em digitos binarios. 

Todos estes programas estao baseados no fato de que a fun?ao 
CHR$ n permite obter o caractere cujo codigo numerico e n, bem como 
no fato de que a fun^ao CODE x (onde x e uma variavel alfanumerica) 
possibilita saber o codigo numerico do primeiro caractere contido na 
variavel alfanumerica x. Desta forma, o primeiro programa (DEX) 
associa a cada numero decimal dois valores guardados no array H. A 
instru5ao na linha 45 permite passar de H para H$. O numero 28 e 
somado para que desta forma, possamos obter todos os caracteres 
desde 0 ate F. No segundo programa, dimensionamos um array 
alfanumerico H$ e testamos se o valor colocado esta compreendido 
entre 0000 e FFFF (linha 30 ). Em seguida, calculamos o valor em 
decimal. O ultimo programa calcula o numero hinario correspondente a 
X e impreme 0 (codigo numerico= 28 ) ou 1 (codigo numerico= 29 ): 
conforme a instrugao INT(X/D) resulte zero ou um. 


EXERCICIOS 

1 . Escreva um programa semelhante a DEX, que converta numeros 
decimais em hexadecimais, no intervalo compreendido entre 0 e 
65535 . 

2 . Suponha que voce deva colocar certas instrugoes em linguagem de 
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maquina nos enderegos 16514, 30000, 65535. Qual sera a representa- 
gao hexadecimal desses enderegos? 

3. Seu programa em linguagem de maquina necessita saber o conteudo 
de certas variaveis do sistema colocadas nos enderegos 16396, 
16438 e 16439. Qual a representagao hexadecimal desses ende¬ 
regos? 

4. Sabe-se que a rotina que verifica se uma tecla foi apertada esta em 
02BB no ROM. Qual o seu enderego em decimal? 

5. O seguinte programa permite realizar SCROLL. Suas instrugoes 
sao: 2A0C40E511210019D101D602EDB0C9. Coloque-as em repre¬ 
sentagao decimal. (Dica: a cada par de numero hexadecimal — 
composto sempre de dois digitos — corresponde um numero 
decimal.) 
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CAPITULOII: 

CARREGAMENTO DE PROGRAMAS EM 
LINGUAGEM DE MAQUINA 


Como o seu computador nao possui um assembler (um programa 
que converta mnemonicos, isto e, instrugoes em simbolos facilmente 
reconheciveis pela mente humana, em codigo binario, para que ele seja 
executado), e preciso faze-lo manualmente. Isto e chamado de 
assembly manual e trata-se de traduzir cada instrugao em hexadecimal. 
Para isto, vamos precisar de um programa que carregue esses 
numeros. Neste capitulo, voce aprendera a fazer este programa, assim 
como tera indicagoes sobre os locais do RAM que deve utilizar para 
colocar suas rotinas em linguagem de maquina. 

No manual que acompanha o seu computador ha diversas suges- 
toes. Vamos examina-las. A primeira refere-se ao uso de instrugoes 
REM. Procure entende-la, a partir das consideragdes que faremos a 
respeito do seguinte programa que voce deve digitar. 

1 REM 1234567 
90 LET E"16514 
100 LET M$” !1 " 

110 IF THEN INPUT 

120 IF THEN STOP ; 


110 IF I HEN .1. 

120 IF M*«"P'-' THEN 
130 POKE E,16SOODE 
140 LET E”E+1 
150 LET TO) 

160 GOTO 110 


HM-CODE M$ (2) -476 
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A primeira instru^ao e REM seguida de sete numeros. Esses 
numeros estao no lugar das instru^oes que iremos digitar. Como sao 
sete as instru^oes, colocamos numeros de 1 ate 7. Poderiamos ter 
colocado quaisquer caracteres. A forma escolhida tern a vantagem de 
evitar erros. Se fossem vinte instrugdes, terfamos digitado: 

1 REM 12345678901234567890 

A segunda instru 9 ao da a variavel E o endere 90 da primeira 
localidade apos a instru 9 ao de REM. 

Colocar o REM no inicio do programa apresenta vantagens 
praticas. Pode-se facilmente localizar o endere 90 do primeiro BYTE 
do programa BASIC. Ele e obtido atraves da instru 9 ao PRINT PEEK 
16396 -i- 256* PEEK 16397 que da 16509 como resultado. A este 
numero devemos somar 5, pois, dois BYTEs sao gastos para definir o 
numero da linha (no endere 90 1650 fica o valor HI e no endere 90 16510 
o valor LO), dois BYTEs para dar o comprimento da linha (no 
endere 9 o 16511 fica o valor LO e no endere 90 16512 fica o valor HI) e 
urn BYTE para escrever REM. Se voce quiser testar, basta entrar com 
PEEK 16514 e encontrara o valor 29 que e o codigo numerico do 
caractere 1. 

As tres instru 9 oes seguintes, nas linhas de numeros 100, 110 e 120, 
definem uma string, inicialmente vazia, o que permitira a voce 
introduzir a instru 9 ao em hexadecimal; atraves da digita 9 ao da tecla 
“P’\ sera possivel interromper o cafregamento do seu assembly 
manual. 

A linha 130 per mite colocar no endere 90 E a instru 9 ao em 
hexadecimal. O resultado final sera do tipo POKE em E um certo 
numero em decimal. Portanto, a sequencia 16* CODE MS-i-CODE 
M$(2)-476 transforma um numero hexadecimal em um numero deci¬ 
mal. Para entender como se chegou a essa formula, basta recordar que 
as instru 9 oes podem ir desde 00 ate FF. Se voce consultar a tabela de 
caracteres, vera que o codigo de 0 e 28 e que o de F e 43. Como a 
fun 9 &o CODE da o codigo numerico do primeiro caractere contido na 
variavel alfanumerica M$, o resultado no caso da instru 9 ao 00 em 
hexadecimal sera: 16* CODE 0 -It CODE 0 - 476, ou seja, zero. Este era 
exatamente o resultado esperado, pois do ^numero 00 em HEX 
corresponde 0 em decimal. Caso a instru 9 ao fosse FF, teriamos: 16* 
CODE F + CODE F - 476, ou seja, 255. Ora, 255 e o maior numero que 
voce pode utilizar numa instru 9 ao “POKE E, v”onde Eeo endere 90 
em decimal, e v, uma quantidade numerica tambem em decimal, ate 
255. Por outro lado, poderiamos ter usado a expressao “(CODE MS- 
28)* 16 -i- CODE M$(2)-28’\ Contudo como se pode facilmente 
verificar, a expressao que estamos utilizando nada mais e do que o 
desenvolvimento desta. 


A linha 140 permite passar do endere 90 E para o endere 9 o 
seguinte, E+-1, enquanto a instru 9 ao 150 possibilita. a leitura do 
restante da string. A ultima instru 9 ao permite a repeti 9 &o do programa 
ate que se digite a letra "P*\ ' 

Entra-se agora com as instru$des em hexadecimal da rotina 
apresentada no inicio do capitulo anterior; ou seja, quando o programa 
de carregamento pedir para colocar a string, digite . 
3E01CD080818F9P. Ele terminara com a indica 9 ao 9/120. Digite agora 
RAND USR 16514. Perceba que a linha 1, apos o carregamento, 
apresenta o seguinte aspecto: 


Y® W4 »> ttttUO 

A segunda sugestao refere-se ao uso de uma string. Para exempli- 
fica-la, vamos recorrer a area onde o computador guarda as variaveis 
para nela colocar a nossa rotina. Antes de faze-lo, e preciso dimensio- 
nar a area a ser ocupada. No caso presente, isto equivale a digitar DIM 
A$(7). Em seguida, precisamos estabelecer o endere 9 o inicial. Para 
tanto, recorremos a variavel VARS que esta no endere 90 16400 
conforme se pode constatar consultando o Apendice 3. Cada instru 9 ao 
sera introduzida atraves da fun 9 ao CHR$ n, onde e o numero em 
decimal correspondente a um certo mnemonico do assembly manual. 
Desta forma, o mesmo programa apresentara agora as seguintes 
instru 9 oes: 


i. 10 
120 
125 
L30 
1 .3 5 
i 40 
145 
150 
160 


205 


DIM A $(7) 

L. E T E P E E K 164 00+25 6 * P E E K 
LET A$(l)'-CHR* 62 
LET A$ (2) =-CHR$ 1 
LET A$(3> -CHR$ 

LET A $ (4) -- CHR $ 

LET Af (5 ) --CHR$ 

LET A*<6) «CHR* 

LET A$<7> "CHRt 
RAND USR E 


1 6 4 0.1, + 6 


a 

a 


24 

249 


Na linha 110 fomos obrigados a somar 6 ao enderefo fornecido 
pela variavel do sistema VARS, porque era necessario levar em conta 
os BYTEs que gastamos para dimensionar a string AS, ou seja: 1 
BYTE para dar nome a string; l BYTEs para dar o numero total de 
elementos; 1 BYTE para escrever o numero de dimensoes; 2 BYTEs 
para dar a dimensao da string. 

A terceira sugestao consiste em reservar um espago no topo do 
RAM. Para isto, devemos calcular este enderego atraves da variavel do 
sistema RTP, e subtrair o resultado do numero de instru^oes que 
iremos utilizar. 
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Com este objetivo em mente, digite e de entrada ao seguinte 
programa: 


100 LET E*PEEK 1638S+256*PEEK 16389 
208 LET E=E~7 

300 POKE 16388,E-256*INT (E/256) 

480 P OKE 16389I NT (E/256) 

588 NEW 


Ele ira redefinir o topo do RAM deixando sete espa$os livres para 
a rotina em linguagem de maquina. Agora basta entrar com este 
programa: 


100 LET E-PEEK 16388+256*PEEK ' 16389 
110 LEI 

120 IF THEN INPUT M$ 

138 IF M$- n P M THEN STOP 

140 POKE £,16*C0DE M$+CDDE M$<2)~476 

150 LET E«E+1 

160 LET 3 TO ) 

170 GOTO 120 


Quando ele pedir para entrar com a string M$, digite 3E01CD0 
80818F9P. Para chamar esta rotina em linguagem de maquina, entre 
com RAND USR (E-7). Note que o enderego inicial e E menos 7, ou 
seja, E menos 6 tamanho da rotina. 

Voce certamente esta curioso em saber se tais sugestoes sao 
equivalentes, ou se ha um ganho real ao se usar uma em detrimento de 
outra. 

A pior sugestao e a segunda, a de colocar a rotina em linguagem de 
maquina na area reservada para as variaveis. Pois, embora voce a 
proteja de ser listada diretamente e possa grava-la em fita magnetica e 
retorna-la posteriormente ao computador junto com o programa em 
BASIC, nao podera utilizar os comandos RUN e CLEAR (ambos 
colocariam todos os valores da string iguais a zero). Alem disso, os 
endere^os dentro da rotina em linguagem de maquina irao mudar 
durante a sua execugao, o que limitara o uso a um so tipo de instru$ao 
de salto (salto relativo, como veremos adiante). 

Na prime ira sugestao, a rotina em linguagem de maquina esta num 
lugar fixo da memoria, sera gravada juntamente com o programa 
BASIC, podendo retornar, quando se desejar, ao computador. A unica 
desvantagem e a de poder ser listada, embora isso nao deva causar 
muita preocupagao, pois, como ja vimos, alem de ela consistir numa 
serie de caracteres (o que a torna ininteligivel para o nao iniciado), ha 
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um tipo de instru^ao a ser examinada adiante, que nao aparece na 
listagem assim como as cinco instrugoes que Ihe seguem. 

A ultima sugestao tern a vantagem imediata de ser a prova de 
comandos do tipo RUN, CLEAR e, mesmo, NEW. Contudo, a rotina 
nao pode ser gravada em fita magnetica diretamente, e os endere 90 s 
serao modificados caso se passe a utilizar uma extensao de memoria. 
Tambem aqui, quando se desejar fazer um programa que rode com ou 
sem extensao, devemos nos limitar a usar apenas saltos relativos na 
rotina em linguagem de maquina. 


EXERCICIOS 

1. Carregue a rotina em linguagem de maquina dada no exercicio 5 do 
primeiro capitulo, utilizando as tres sugestoes de carregamento que 
acabamos de estudar. 

2. Escreva um programa de carregamento que utilize a area das 
variaveis para guardar a rotina em linguagem de maquina, porem 
usando a instrugao POKE. 
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CAPITULO III: 

ALGUNS MNEMONICOS EM LINGUAGEM 
DE mAQUINA E A SUA IJTILIZAQAO 


Ate agora so lidamos com numeros. Contudo, eles correspondem 
a mnemonicos. Pode-se verificar isto consultando o apendice do 
manual que veio junto com o seu computador. Por exemplo, a rotina 
em linguagem de maquina que utilizamos nos dois primeiros capitulos 
apresenta os seguintes mnemonicos: 


numero em HEX 

mnemonic*} 

3E 

LD A, N 

01 

N= 1 

CD 

CALL NN 

08 

N = 8 

08 

N = 8 

18 

JR DIS 

F9 

DIS = 7- 


Vamos demoninar a tabela formada por numeros hexadecimais de 
codigo objeto (o codigo que colocaremos no computador) e a tabela 
dos mnemonicos de codigo fonte (as instru^oes dadas numa forma que 
fica facil de ser compreendida pela mente humana). 

No decorrer desta explanagao, estudaremos algumas das diversas 
instru^oes do Z80A, que na sua forma basica sao 245, e que, atraves 
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das diversas permuta^oes, chegam a mais de 800 . Nao e preciso se 
esfor?ar em decora-las; para isto existem tabelas (ver Apendice 4 ). 
Veremos, nesta obra de carater introdutorio, apenas um subconjunto 
dessas instru?6es, deixando, para uma abordagem posterior, a investi- 
ga$ao de todo o conjunto. 

Cada instru$ao define uma seqiiencia de operates a serem 
realizadas. Elas podem ter o comprimento variando entre um a quatro 
BYTEs. Podemos reuni-las em seis grupos (dos quais aqui estudare- 
mos apenas os cinco primeiros): 

I) Grupo de Transference de Dados; 

II) Grupo de Operates Aritmeticas e Logicas; 

III) Grupo de Salto, Chamada e Retorno; 

IV) Grupo de Rotasao e de Deslocamento; 

V) Grupo de Manipula^ao de BIT; 

VI) Grupo de Controle de Entrada e Saida. 

Os BYTEs presentes nas instrugoes podem ser divididos em 
BYTEs de: 

a) Instrugao; 

b) Dados; 

c) Endere$os; 

d) Referencias a Dispositivos; 

e) Deslocamentos. 

Ha doze formas de combinar esses BYTEs em conjuntos de um a 
quatro BYTEs conforme a tabela abaixo revela. 

Numero de BYTEs Tipo de BYTE 

1 Opera^ao 

2 Opera9ao-Opera$ao 
Operasao-Dado 
Opera^ao-Deslocamento 
Opera9ao-Dispositivo 

3 Opera9ao-Dado-Dado 
Opera9ao-Endere9o(LO)-Endere9o(HI) 
Opera9ao-Opera9ao-Deslocamento 

4 Opera9ao-Opera9ao-Dado-Dado 
Opera9aO“Opera9ao-Endere9o(LO)-Endere9o(HI) 
Opera9ao-Opera9ao-Deslocamento-Dado 
Opera9aO“Opera9ao-Deslocamento-Opera9ao 

A seguir, daremos dois exemplos com o objetivo de explicar como 
se passa de seqiiencias de numeros HEX para mnemonicos, e como 
atraves disto pode-se chegar a compreender aquilo que a rotina em 
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linguagem de maquina pretende realizar. Voce nao precisa se inquietar 
caso nao entenda as instru 9 oes — elas serao explicadas, em detalhe, 
nos capitulos seguintes. 

Mas, antes de passar aos exemplos, cumpre fazer as seguintes 
observa 9 oes: 

a) opera 9 oes consistem em a 9 oes que desejamos implementar no 
computador; 

b) a CPU (unidade central de processamento) e composta de uma 
unidade logico-aritmetica, de uma unidade de controle e de um 
clock (relogio) que marca o tempo que cada a 9 §o leva para ser 
executada; neste sentido, mesmo a instru 9 ao NOP (nao fa 9 a nada) 
leva um certo tempo para ser implementada; 

c) a CPU esta ligada a dispositivos de entrada (geralmente o teclado), a 
dispositivos de saida (em geral, um monitor ou uma impressora) e a 
unidades de memoria (o ROM, o RAM, ou, mesmo, a memoria 
guardada em fita magnetica); 

d) conforme voce pode constatar, toda vez que uma opera 9 ao envolve 
um endere 90 ou um dado de 16 BITs, o primeiro BYTE refere-se 
sempre ao BYTE menos significativo, e nao ao mais significativo, 
como se poderia intrisicamente pensar. 

Vamos analisar, em primeiro lugar, a rotina que usamos ate este 
momento. Ela pode ser colocada na seguinte forma: 

codigo objeto codigo fonte rotulo comentario 

3E01 LD A,N INICIO oper-dado 

CD0808 1 CALLN N oper-end (LO)-end(HI) 

18F9 JR INICIO oper-desl 

A primeira instru 9 ao — a instru 9 ao LOAD, abreviada LD — pode 
ser entendida, dentro de certos limites, como semelhante a instru 9 ao 
LET em BASIC. Assim, LD A,01 consiste em colocar em A, chamado 
de ACUMULADOR, o valor 01. Pertence, portanto, ao grupo I: o 
grupo das opera 9 &es de transferences de dados. 

A segunda instru 9 ao — CALL NN — pode ser considerada 
correspondente a instru 9 ao GOSUB em BASIC. Como e evidente, 
pertence ao grupo V. Atraves dela estamos chamando uma sub-rotina 
no ROM, presente no endere 90 8-1-8*256, isto e, no endere 9 o 2056 em 
decimal. Note, mais uma vez, que o primeiro BYTE do endere 90 e o 
BYTE menos significativo. 

A ultima instru 9 ao — JR DIS — refere-se a instru 9 ao salte 
(“JUMP”). Ela altera o PC (contador de programa), fazendo com 
que o programa passe a ser executado num local determinado pelo 
deslocamento. No caso presente, como veremos mais adiante, trata-se 
de um salto relativo, que da ao PC um valor que leva o programa de 
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novo para a instrugao LD A,N. A instrugao “JUMP” e, dentro de 
certos limites, semelhante a instrugao GOTO em BASIC. 

Em suma, nossa rotina consiste em carregar o acumulador de um 
certo valor, em seguida, ela chama uma sub-rotina no ROM que 
imprime o caractere correspondente a esse valor, para, finalmente, 
repetir o procedimento, indefinidamente,^ atraves de um salto relativo 
que a leva de novo para o seu imcio. E exatamente por is so que a 
execugao da rotina e sempre interrompida com indicagao de erro do 
tipo 5. 

Esse trabalho de desmontar a rotina em linguagem de maquina 
chama-se disassembly. Vamos realiza-lo em relagao a rotina, dada no 
quinto exercicio do capitulo I. Se a colocarmos no enderego 30 000 
(supondo que sua maquina possui 16 K de memoria), teremos a 
seguinte tabela: 


ENDEREC0 C0D.OBJET0 C0D»F0NTE 


30000 

2A0O40 

LD HL, (16396) 

30003 

E5 

PUSH HL 

30004 

112 : 1.00 

LD DE, 33 

30007 

19 

ADD.HL,DE 

30008 

01 

POP DE 

30009 

01 [>602 

LD BC,,726 

300:12 

EDB0 

LDIR 

300:1.4 

C9 

RET 


A primeira instrugao — LD HL, (NN) — consiste em colocar no 
par de registradores HL o conteudo do enderego indicado por NN. 
Este enderego e 12 (0C em HEX) H- 64 (40 em HEX) * 256 « 16396. 
Consultando o Apendice 3, descobre-se que 16396 e o enderego da 
variavel do sistema DFILE, o qual da o enderego do primeiro caractere 
no arquivo de imagem. Portanto, o par de registradores HL esta 
apontando para esse enderego. Como ja vimos, os enderegos sao 
sempre dados em 16 BITs. Logo, a instrugao LD HL (NN) e 
semelhante em BASIC a: 


LET L =PEEK N LET L =PEEK 16396 

no caso presente , a 

LET H=PEEK N-hI LETH=PEEK 16397 

A segunda instrugao — PUSH HL (acrescente) — refere-se a pilha 
de dados (“STACK”). Esta pilha nada mais e do que uma forma de 
guardar os dados. Ela obedece a uma regra chamada “LIFO”, 
abreviatura da expressao inglesa last in, first out (o ultimo a entrar e o 
primeiro a sair). 
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Em outras palavras, pode-se compara-la a uma pilha de livros: para 
retirar um, e preciso comegar pegando o que esta sobre todos os 
outros, a fim de evitar o risco de ver a pilha desabar. A instrugao 
PUSH HL e semelhante em BASIC a fazer uni POKE no enderego 
dado pelo SP (ponteiro da pilha); isto e, a entrar com: 

POKE SP-1, H 
POKE SP-2, L 

Portanto, quando acrescentamos algo na pilha, o SP diminui. O novo 
SP e igual ao anterior subtraido de dois. Como o valor L foi o ultimo a 
entrar, ele sera o primeiro a sair. 

A terceira instrugao - LD DE, NN — coloca no par de registrado¬ 
res DE o valor 33 (21 em HEX). Note que o BYTE mais significativo e 
zero, e que ele vem depois do BYTE menos significativo. 

A quarta instrugao — ADD HL, DE adiciona ao conteudo de HL o 
valor presente em DE. Desta forma, HL contem agora o enderego do 
ultimo BYTE da primeira linha do arquivo de imagem. 

Na quinta instrugao — POP DE (remonte) — estamos, inversa- 
mente a segunda instrugao, retirando da pilha dados para colocar no 
par de registradores DE. Como POP aumenta o SP de dois, teremos 
que a instrugao POP DE, no presente caso, e semelhante em BASIC a: 

LET D = PEEK (SP-l)^H 
LET E = PEEK (SP-2) = L 

Logo, DE guarda agora o valor de HL anterior a quarta instrugao, ou 
seja, o enderego do primeiro BYTE do arquivo de imagem. Note que, 
apos esta instrugao, o SP voltou ao seu valor original, isto e, anterior a 
execugao da segunda instrugao. Quando isto nao ocorrer, o sistema ira 
sofrer um desastre (um crash). 

A sexta instrugao — LD BC, NN — coloca, no par de registrado¬ 
res BC, o valor 214 (D6 em HEX) + 2 * 256 = 726. 

A penultima instrugao — LDIR —, que contem dois BYTEs, vai 
transferir um bloco de dados, que se inicia no enderego indicado por 
HL, para o enderego iniciado com o enderego indicado por DE. O 
numero total de transferences a serem feitas e dado pelo par de 
registradores BC. Durante a execugao desta instrugao, os valores de 
HL e de DE sao incrementados, e.o de BC, diminuidos ate chegar a 
zero. 

A ultima instrugao — RET — possibilita que haja um retorno para 
o programa em BASIC. 

O que realiza, em suma, este conjunto de instrugoes em linguagem 
de maquina? 

Ele, simplesmente, faz um SCROLL. 
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Podemos agora, descrever, com maiores detalhes, a organizagao 
do Z80A. 

Ele possui dois conjuntos de oito registradores cada um. O 
principal, formado pelos registradores A, F, B, C, D, E, H e L, pode 
ser afetado diretamente pela rotina. O alternative, composto pelos 
registradores A’, F\ B’, C\ D\ E\ H’ e L’, so pode ser manipulado 
indiretamente, corrio veremos mais adiante. 

Como ja foi assinalado, A e o acumulador. B, C, D, E, H e L 
podem ser usados como registradores de oito BITs, ou aos pares, BC, 
DE e HL, como registradores de 16 BITs. Neste caso, B, D e H 
contem o BYTE mais significativo, enquanto C, E e L, o menos 
significativo. O registrador F guarda os diversos “FLAGS” (sinaliza- 
dores). Estes indicam as condi 9 oes internas do microprocessador e 
podem ser usados, como veremos, nas instrugoes de Salto, Chamada e 
Retorno. Ha ainda quatro registradores de 16 BITs (isto e, so podem 
ser usadas aos pares): IX, IY, SP e PC. Os dois primeiros, denomina- 
dos registradores indexados, serao descritos no proximo capitulo; os 
outros dois, SP e PC, como ja foi assinalado, referem-se, respectiva- 
mente, ao ponteiro da pilha de dados e ao contador de programa. 

Finalmente, ha dois outros registradores de 8 BITs, o registrador 
de interrupsao I e o de refresh R, que so serao estudados em obra 
posterior, de carater nao introdutorio. 
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CAPITULO IV: 

GRUPO DE TRANSFERENCE DE DADOS 


Nosso objetivo, neste capitulo e nos quatro subseqiientes, e o de 
examinar as diversas instru^oes que podem ser implementadas no 
Z80A. A melhor forma de estudar tais instrugoes consiste em 
manipula-las, atraves de exercicios. Portanto, para cada tipo de 
instru^ao, existe uma rotina em linguagem de maquina. Ela deve ser 
implementada com o auxflio do programa de carregamento dado no 
capitulo II. (Utilizaremos aqui a terceira sugestao; ou seja, modificare- 
mos o topo do RAM, e o primeiro endere 90 livre para linguagem de 
maquina sera 30000. Caso voce nao tenha 16K de memoria, reserve o 
espa9o acima de 18000. Se voce tiver 48K, entao o endere 9 o 60000 sera 
apropriado. Lembre-se de fazer as modifica9des necessarias). 

A vantagem deste metodo esta no fato de ele procurar, tanto 
quanto possivel, aproximar a linguagem de maquina da programa 9 ao 
em BASIC. As rotinas em linguagem de maquina sao pequenas a fim 
de reduzir a possibilidade de ocorrencia de um crash. Elas serao, na 
medida do possivel, progressivamente ampliadas conforme se avan 9 a 
os capitulos. Desta forma, aprende-se a dividir um programa em 
pequenas unidades e a combina-las de modo a produzir, no final, o 
resultado desejado. 

Antes de dar a string para o programa de carregamento, a rotina e 
apresentada sob a forma de endere 90 , codigo objeto, codigo fonte. 
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Aprenda a ler a rotina, pois, a partir do proximo capitulo, nao sera mais 
dada a string. Cada rotina e explicada em detalhe, embora ela nao 
ilustre todos os exemplos possiveis. Essa tarefa e deixada para voce. 

EXERCICIOS ILUSTRATIVOS 


I - Instru^ao NOP 

Esta instrugao, como ja foi dito, significa no operation ou seja, nao 
realize nenhuma opera^ao. Escreva a seguinte rotina: 



NOP 


•v* 

f 


Para isto,entre com a string “00C9P”. Digite PRINT USR 30000. 
Qual o resultado? 

Voce obtem 30000, isto e, 117* 256+48. Em outras palavras, USR 
retorna com o valor do par de registradores BC. O unico efeito causado 
por NOP foi o de produzir um certo atraso no retorno — o tempo gasto 
para implementa-la. 


II - Instrugao LD registrador, dado. 

Todo registrador do conjunto principal pode ser carregado direta- 
mente com dados. Isto e ilustrado pela seguinte rotina: 


30000 

38002 

30004 


0600 


LD B,0 
L.D C,10 
RET 


Entre com a seguinte string: “06000E0AC9P”. Digite agora 
PRINT USR 30000. Qual o resultado? 

Obtem-se 10, ou seja, o valor colocado no registrador C, uma vez 
que B foi carregado com zero. Para poder variar os valores de B e de 
C, entre com o seguinte programa: 


.1.0 INPUT X 
20 INPUT Y 
30 POKE 30001 ,,X 
40 POKE 30083,Y 
50 PRINT "VALOR DE B=- 
60 PRINT "VALOR DE C~ 
70 PRINT USR 30000 
80 GOTO 10 


" 7 PE 

"?PE 


:K 30001 
T< 30003 


Atraves dele, obtem-se, na terceira linha, o resultado do registra¬ 
dor B multiplicado por 256 somado ao registrador C. 

O que ocorre quando voce entra com um numero negativo? 
Ele e somado a 256 e, em seguida, processado. Experimente, por 
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exemplo, -255 e -1 para X e Y, respectivamente. Qual o resultado? 
511, isto e, Q-255+256) * 256 + (256+(-l)]. 

A tabela abaixo fornece o codigo em HEX dessas instrugoes. 

LD A,N 3EN 

LD B,N 06N 

LD C,N 0EN 

LD D,N 16N 

LD E,N 1EN 

LD H,N 26N 

LD L,N 2EN 

(N e um numero em HEX no intervalo entre 00 e FF) 

Pode-se entender esta instrugao como igualmente a instrugao LET em 
BASIC ou seja, LD A, N e semelhante a LET A=N onde N varia no 
intervalo entre zero e duzentos cinqiienta e cinco. 


Ill * Instrugao LD par de registradores, dado 

O carregamento aqui, ainda que imediato, utiliza-se de registrado¬ 
res de 16 BITs, ou seja, BC, DE, HL, SP, IX e IY. Para ilustra-lo, 
entre com a seguinte rotina: 


30000 
3 U U 0,3 


012000 

C9 


BC •. 32 


RET 


Digite a string “012000C9P” e entre com PRINT USR 30000. Qual 
o resultado? 

Exatamente aquele que esta presente no par de registradores BC, 
ou seja, 32. 

Elabore, como exercicio, um programa em BASIC que lhe permita 
variar o valor colocado no par BC. 

A tabela abaixo fornece o codigo em HEX dessas instrugoes. 


LD BC; NN 01NN 

LD DE,NN 11.NN 

LD HL, NN 21 NN 

LD SP, NN 31 NN 

LD IX, NN DD21NN 
LD IY, NN FD21NN 

(NN e um par de numeros em HEX variando no intervalo 0000-FFFF) 


Podemos entender essa instrugao como sendo semelhante a 
instrugao LET em BASIC, ou seja. LD BC, NN e semelhante a LET 
BC = NN, onde NN varia entre 0e 65535. 
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IV — Instrugao LD dado de um registrador (fonte) para outro 
registrador (destine) 

Pode-se transferir o valor contido num registrador para outro 
registrador. Apenas este ultimo e alterado pela instrugao A rotma 
abaixo ilustra isto, ao passar o conteudo de A para o registrador C. 


30002 
30004 

30003 


3E'10 

0600 

4F 

C9 


LD A,16 
LD 8,0 
LD C, A 
RET 


8 S *cTrcsultado^PRlNTUSR30WM e precisamente o valor contido 
no acumuS A. Escreva um programa cm BASIC que pernuta vanar 

° “Ttabela abaixo forncce o codigo cm HEX dcssas i„stru s 6cs. 


LD A,A 
LD A,B : 
LD A,C 
LD A,D 
LD A,E 
LD A,H 
LD A,L 

LD E,E 
LD E,A 
LD E,B 
LD E,C 
LD E,D 
LD E,H 


LD B,B : 
LD B,A : 
LD B,C : 
LD B,D 
LD B,E : 
LD B,H 
LD B,L 

LD H,H 
LD H,A 
LD H,B 
LD H,C 
LD H,D 
LD H,E 
LD H,L 


LD C,C : 49 
LD C,A : 4F 
LD C,B : 48 
LD C,D : 4A 
LD C,E : 4B 
LD C,H : 4C 
LD C,L : 4D 

LD L,L : 6D 
LD L,A : 6F 
LD L,B : 68 
LD L,C : 69 
LD L,D : 6A 
LD L,E : 6B 
LD L,H : 6C 


LD D,D 
LD D,A 
LD D,B 
LD D,C 
LD D,E 
LD D,H 
LD D,L 


LD E,L : 5D LD H,L : to lu . - 

Todas essas instrugoes podem ser consideradas semelhantes a 
t FT x=Y em BASIC, onde X e Y sao variaveis cujo valor esta sempre 
nef intervale entre 0 e 255. Quando um acumulador e carregado com o 
seu proprio conteudo, temos uma instrugao equivalen 

V - Instrugao LD dado, a partir de uma localidade na memoria, no par 
de registradores HL (enderegamento absoluto) 

Diferentemente do que estudamos ate agora esta mstmgao 
carrega, o par de registradores HL, com o conteudo do enderego 


iriciicado por NN. Para diferencia-la da instrugao LD HL, NN, 
colocamos o par NN entre parenteses. Experimente a seguinte rotina: 


30000 2A0C4B 

30003 44 

30004 4D 

38005 C9 


LD HL,(16396) 
LD B H 
LD C,L 
RET 


String - “2A0C40444DC9P” 

PRINT USR 30000 indica o enderego do primeiro BYTE no 
arquivo da imagem. Para mostrar isto, digite este programa: 


10 LET A-USR 30000+1 
20 POKE A,1 
30 POKE A+31,i 
4 0 P 0 K E A+2 1 + 3 3 ? 1 
50 POKE A+21*33+31,1 


Ele ira colocar o caractere numero 1 nos quatro cantos da tela. 
O codigo desta instrugao em HEX e 2A(NN), onde (NN) designa 
um enderego. Ela pode ser entendida como semelhante ao seguinte 
conjunto de instrugoes em BASIC: 


LET H - PEEK N-H 
LET L — PEEK N 


VI - Instrugao LD dado, a partir de uma localidade na memoria, num 
par de registradores (enderegamento absoluto). 

A unica diferenga entre esta instrugao e a anterior e o seu 
tamanho. Todas elas tern quatro BYTEs. A rotina abaixo exemplifica 
este tipo de instrugao. 

38000 ED4B3440 LD BC,<16436) 

30004 0600 LD B.,0 

38806 C9 RET 

String - “ED4B34400600C9P” Colocamos no par de registradores BC 
o conteudo do enderego indicado por (NN), no caso presente, a 
variavel do sistema FRAMES. A instrugao LD B,0 permite que PRINT 
USR 30000 gere um numero aleatorio entre 0 e 255. 

A tabela abaixo fornece o codigo em HEX dessas instrugoes. 

LD BC, (NN) ED4B NN 

LD DE, (NN) ED5B NN 

LD HL, (NN) ED6B NN 

LD SP, (NN) ED7B NN 

(NN e um enderego entre 0000 e FFFF) 
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Observances: 

a) 6 sempre preferfvel utilizar LD HL, (NN) com tres BYTEs dp que 
com quatro; 

b) todas essas instru?6es sao semelhantes em BASIC, por exemplo, ao 
seguinte conjunto de instru§oes: 

LET B = PEEK N-i-1 
LET C = PEEK N 

VII - Instru?ao LD dado, a partir de uma localidade na memoria, num 
registrador (endereijamento indireto). 

Atente para a rotina abaixo: 

30800 210040 LD HL,16384 

30003 4E LD C,< HL) 

3000,4 0600 LD 8,0 

30006 C9 RET 

String:“2 100404E0600C9P” Veja se voce ja consegue antecipar o 
resultado. Demos a HL o endere?o 16384, o da variavel do sistema 
ERR.NR. A seguir, carregamos o registrador C com o conteudo desse 
enderego. Desta forma, PRINT USR 30000 dara 255. 

A tabela abaixo fornece o codigo em HEX dessas instrufdes. 

LD A, (NN) 3A(NN)LD A, (HL) 7E LD A, (BC)0A LD A, (DE) 1A. 

LD B, (HL) 46 

LD C, (HL) 4E 

LD D, (HL) 56 

LD E, (HL) 5E 

LD H, (HL) 66 

LD L, (HL) 6E 

Observances: 

a) a instrunao 7E e de uso freqiiente nas rotinas em linguagem de 
maquina; contudo, seu codigo e utilizado pelo programa monitor 
para caracterizar que um numero esta-na forma binaria de ponto 
flutuante. A conseqiiencia disto e nao podermos listar nem esta 
instrunao nem as cinco seguintes — elas ficam invisiveis na 
listagem, embora estejam presentes no programa; 

b) essas instrunoes sao semelhantes a instrunoes do tipo 

LET C = PEEK HL 

c) note que o acumulador pode ser carregado, nao apenas de (HL), 
mas de (BC), (DE) ou mesmo de (NN), diferentemente dos demais 
registradores de oito BITs. 
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VIII - Instru^ao LD dado, a partir de uma localidade na memoria, num 
registrador (enderenamento indexado) 

Alem dos enderenamentos absoluto e do indireto, pode-se utilizar 
o indexado, atraves dos registradores indexados IX e IY. Eles sao 
identicos quanto as fun^oes; portanto, o que for descrito em rela^ao a 
um e valido em rela^ao a outro, 

A grande vantagem na sua utilizagao reside na possibilidade de 
somar constantes aos endere^os que eles indicam. Contudo, no caso 
particular dos computadores que estamos estudando, nao se pode 
utilizar o registrador IX no modo “SLOW”. Em compensanao, IY 
aponta para o enderego 16384, ou seja, o imcio das variaveis do 
sistema. 

Para demonstrar o seu uso, entre com a seguinte rotina: 

38000 FD7E00 LD A,(IY) 

38003 4F LD C ? A 

30004 0600 LD B ? 0 

30006 C9 RET 

String: “FD7E004F0600C9P” 

A instrunao PRINT USR 30000 fornece o valor da variavel do 
sistema ERR NR, ou seja, 255, comp ja foi visto. 

A tabela abaixo fornece o codigo dessas instru^oes em HEX. 

LD A, (IY+dis) FD7E N 

LD B,(IY~hdis) FD46 N 

LD .C, (IY+dis) * FD4E N 
LD D,(IY+dis) FD56 N 

LD E,(IY+dis) FD5E N 

LD H,(IY+dis) FD66 N 

LD L,(IY+dis) FD6E N 

(N e um numero em HEX no intervalo entre 00 e FF) 

Observances: 

a) as instrunoes que usam IX tern o mesmo codigo que IY, com 
excenao do primeiro BYTE, que, em vez de FD, e DD; 

b) o deslocamento pode-se dar no intervalo compreendido entre -128 e 
+127, conforme veremos no capitulo VI, ao estudarmos a conven- 
nao complemento ,de dois. 

c) estas instrugoes sao semelhantes a instru^oes do tipo 
LET registrador = PEEK (IY+dis) 

IX — Instru^ao LD dado, a partir do acumulador, numa localidade de 
memoria (enderenamento absoluto) 

Ao contrario das instrunoes anteriores, as quais carregavam o 
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acumulador a partir de uma localidade na memoria. trata-se aqui de 
colocar num enderego o valor presente no acumulador. 

Isto pode ser ilustrado pela seguinte rotina: 


30000 

30002 

30005 


3E10 

323A75 

C9 


LD A,16 
LD (30010)?A 
RET 


String: “3E10323A75C9P” 

Para testar estas instrugoes, entre com o seguinte programa: 

10 INPUT X 

20 POKE' 30001 ?X 

30 RAND IJSR 30000 

40 PRINT PEEK 30010 

50 GOTO 10 Ele 

possibilita-lhe colocar diversos valores no acumulador e verificar a 
rotina atraves da instrugao presente nalinha40. Este tipo de instrugao, 
cujo codigo em HEX e 32 (NN) pode ser interpretado como semelhan- 
te ao seguinte conjunto de instrugoes em BASIC: 

LET A = X 
POKE NN, A 

(NN especifica urn enderego no intervalo entre 16384 a 32768, caso 
se possua uma extensao de 16K). 

X — Instrugao LD, a partir do par do registradores, HL, numa 
localidade na memoria (enderegamento absoluto). 

Analoga ao tipo de instrugao anterior, com umaunica diferenga: o 
conteudo e transferido a partir do par de registradores HL. 


30003 


210440 

223A75 

09 


LD HL16388 
LD <30010),HI¬ 
RE'!' 


String: “210440223A75C9P” 

Para constatar o que a rotina acima realiza, entre com o seguinte 
programa: 

10 RAND IJSR 30000 

20 PRINT PEEK 30010*256*PEEK 30011 


Qual o resultado obtido? Encontra-se 16388, ou seja, o valor 
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contido no par de registradores HL. Isto indica que esta instrugao — 
cujo codigo em HEX e 22 (NN) onde (NN) indica um enderego no 
intervalo entre 16384 e 32768 — e semelhante ao seguinte conjunto de 
instrugoes em BASIC: 

LET H = A 
LET L — B 
POKE (NN), B 
POKE (NN+1),A 

XI — Instrugao LD, a partir de registradores de 16 BITs, numa 
localidade na memoria (enderegamento absoluto). 

O mesmo tipo de instrugao que a anterior — a unica diferenga 
reside no comprimento das instrugoes: todas elas possuem 4 BYTEs. 

A tabela abaixo fornece o codigo em HEX dessas instrugoes. 

LD (NN), BC ED43( NN) 

LD (NN), DE ED53 (NN) 

LD (NN), HL ED63 (NN) 

LD (NN), SP ED73 (NN) 

(NN e um enderego no intervalo compreendido entre 16384 e 32768) 


XII — Instrugao LD dado, a partir de um registrador, numa localidade 

na memoria (enderegamento indireto) 

/ 

E necessario que o local ja tenha sido especificado, para que se 
possa utilizar este tipo de instrugao. 


30003 


300W3 

30006 


213A75 

3E20 

77 

09 


LD HL,30010 
LD A,32 
LD (HL),A 
RET 


String : “213A753E2077C9P” Para testar esta rotina, entre com o 
programa abaixo. 


10 INPUT X 
20 POKE 30004,X 
30 RAND USR 30000- 


40 PRINT PEEK 30010 




30 GOTO 10 


Este permite variar o valor colocado no acumulador e testar se gle 
e realmente transferido para o enderego indicado por HL. 
Observagoes: 

a) o acumulador, diferentemente dos u~uos registradores de 8 BITs, 
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pode transferir dados, nao so para o enderego indicado por HL, 
como para os que sao indicados por BC e DE, 

b) o enderego indicado por HL tambem pode ser carregado diretamen- 
te sem o uso de quaisquer registradores, atraves da instrugao L 
(HL), N (codigo em HEX: 36 N), onde N e um numero em HEX no 

intervalo 00 a FF; 

c) as instrugoes deste tipo podem ser vistas como semelnantes ao 
seguinte conjunto de instrugoes em BASIC. 

LET registrador = X 

POKE enderego indicado por HL, X 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 

LD (HL), A 77 
LD (HL), B 70 
LD (HL), C 71 
LD (HL), D 72 
LD (HL), E 73 
LD (HL), H 74 
LD (HL), L 75 

XIII — Instrugao LD dado, a partir de um registrador indexado, numa 
localidade na memoria (enderegamento indexado) 

Antes de realizar o exercicio, releia com atengao o oitavo 
exercicio deste capitulo. 

30000 3E05 f-J> ^,5 , 

30002 FD7700 LU 

30005 C9 

Nao e necessario especificar IY porque, como jafoi estudado, ele 
automaticamente aponta para o inicio das variaveis do sistema. Para 
estudar as diversas denotagoes de erro, entre com o segumte programa 
e rode-o varias vezes, variando o valor de X. 

10 INPUT X 

20 POKE 30001,X 
30 RAND USR 30000 

Antes de dar valor a X, leia as observagoes que o manual do seu 
computador tece a respeito dos valores que podem ser colocados neste 
enderego (16384). A proposito, qual o unico valor de X que tornaria 
possivel que uma instrugao GOTO 10 colocada na linha 40 iQSse 

obedecida? 
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A tabela abaixo fornece o codigo em HEX dessas instrugoes. 

LD(IY+dis),A FD77N 
LD(IY+dis),B FD70N 
LD(IY-i-dis),C FD71N 
LD(IY+dis),D FD72N 
LD(IYq-dis),E FD73N 
LD(IY+dis),H FD74N 
LD(IYn-dis),L FD75N 

(N e um numero em HEX no intervalo entre 00 e FF) 

As mesmas observagoes feitas em relagao ao exercicio VIII sao 
validas aqui. 

Esta instrugao e semelhante em BASIC ao conjunto de instrugoes do 
tipo LET registrador = X POKE enderego indicado por (I Y-i-dis), X 

XIV - Instrugoes que se referem ao “STACK” 

Como ja foi visto antes (capitulo III), podemos colocar ou retirar 
coisas do “STACK”, isto e, podemos fazer um PUSH (acrescente) par 
de registradores ou um POP (remonte) par de registradores. 

Todo o cuidado em manipular o “STACK” esta em nao alterar o 
valor do seu ponteiro apos o uso da rotina. 


30000 

112000 

LD DE,;: 

30003 

D5 

PUSH DE 

30004 

C1 

POP BC 

30005 

0600 

LD B,0 

30007 

C9 

RET 


String: “112000D5C10 600C9P” 

Veja se consegue antecipar o resultado. Ele e o valor colocado no 
registrador E. Note que o SP permanece o mesmo apos o termino da 
rotina. Escreva um programa em BASIC que permita variar o valor de 
E e retorna-lo atraves do registrador C. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 

PUSH BC C5 POP BC Cl 

PUSH DE D5 POP DE D1 

PUSH HL E5 POP HL El 

PUSH AF F5 POP AF FI 

PUSH IX DDE5 POP IX DDE1 

PUSH IY FDE5 POP IY FDE1 

Observagoes: 

a) pode-se utilizar a instrugao PUSH para salvar valores presentes nos 
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registradores de 16 BITs, apos o epic clcs rctomam atraves da 
instru^ao POP; 

b) o registrador de 16 BITs AF e formado pelo acumulador A e pelo 
registrador do estadodos-TLAGs”(sinalizadores)F (este ultimo sera 
estudado no capitulo VI); 

c) a semelhan^a com instru^oes em BASIC encontra-se no final do 
capitulo III. 

XV - Instrugoes que trocam os registradores principais pelos alterna¬ 
tives. 

Acabamos de mencionar (na primeira observagao do ultimo 
exercicio) que as instru 9 oes PUSH e POP podem ser utilizadas para 
salvar os valores contidos nos registradores. Contudo, existe uma 
instru 9 ao bem mais simples que permite realizar esta tarefa, ou seja, 
EXX (codigo em XEX: D9). Se for necessario preservar tambem o 
conteudo do acumulador, ou o estado presente dos ‘‘FLAGs^ , ou 
ambos, devemos acrescentar a instru 9 ao EXX a instru 9 ao EX AF, AF 
(codigo em HEX: 08). A rotina abaixo exemplifica a forma correta de 

se efetuar a troca. 


30000 

2600 

LD H,0 

30002 

OP'Opl 

L0 L,32 

30004 

08 

EX AF ? AF 

38005 

09 

EXX 

30086 

09 

EXX 

38807 

08 

EX AF,AF 

38008 

40 

LD C?L 

38009 

44 

LD B ,H 

30810 

C9 

RET 


String: ‘ ‘26002E2008D9D9084D44C9P’ ’ 

PRINT USR 30000 dara como resultado o valor colocado no 

registrador L. _ 

Tambem e possivel trocar o valor contido no par DL, pelo 

presente no par HL, atraves da instru 9 ao EX DE, HL (codigo em 
HEX: EB). 

XVI — Instru 9 oes que transferem blocos de dados 

Antes de descrever LDIR e LDDR (ver capitulo III), vamos 
estudar as mesmas instru 9 oes sem repeti 9 ao automatica, isto e, LDI e 

LDD. • ♦ , , . 

Estas duas instr^oes, cada uma com compnmento de dois 

BYTEs, transferem o conteudo de uma localidade na^ memoria, 
indicada por HL, para outra, indicada por DE. Se a instru9&o for LDI, 
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os registradores HL e DE sao incrementados de um; se for LDD, eles 
sao diminuidos de um. Em ambos os casos, BC atua como um 
“registrador de contagem” e e diminuido de um cada vez que a 
instru 9 ao e implementada. 

LDIR e LDDR fazem a mesma coisa, de forma automatica, ate 
que BC tenha o valor zero. 


30000 

014A01 

LD BC ? 330 

38803 

2A0C40 

LD HL,<16396) 

30006 

09 

ADD HL,BC 

30087 

EB 

EX DE,HL 

30008 

2A0C40 

LD HL,(16396) 

300.11 

016B01 

LD BC,363 

30014 

09 

ADD HL,BC 

30015 

ED80 

LDIR 

30017 

0E015 

LD C,21 

30019 

C9 

RET 


String: “014A012A0C4009EB2A0C40 016B0109ED- 
B00E15C9P” 

Esta rotina faz um “SCROLL” no sentido inverso da. parte 
inferior da tela (as dez primeiras linhas nao sao alteradas). Ela pode ser 
utilizada a partir do seguinte programa em BASIC: 

10 Did C$<32) 

15 PRINT AT 9,0? M FICO IMOVEL" 

20 INPUT C* 

30 PRINT AT USR 30000»0;C$<TO 32) 

48 GOTO 20 

Voce ja deve estar capacitado a acompanhar toda a rotina. Para 
ajuda-lo, vamos dar os valores de HL, DE e BC, antes de a instru 9 ao 
LDIR ser implementada. 

HL - aponta para o 363° lugar no arquivo de imagem, ou seja, para o 
inicio da 12 a linha do video (note que HL e a fonte); 

DE - aponta para 330° lugar no arquivo de imagem, ou seja^ para o 
inicio da ll a linha do video (note que DE e o destine); 

BC - aponta a quantidade de transferences a serem feitas: 363 
transferences. 

A tabela abaixo fornece o codigo em HEX destas instru 9 oes. 


LDI 

EDA0 

LDD 

EDA8 

LDIR 

EDB0 

LDDR 

EDB8 
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Este tipo de instrugao (por exemplo, LDI) e semelhante ao seguinte 
conjunto de instrugoes em BASIC 

LET DE = X 
LET HL= Y 
POKE X= PEEK Y 
LET BC = BC -1 
LET DE =DE l- 1 
LET HL = HL + 1 

XVII_Instrugoes que aumentam (INC) ou diminuem (DEC) 

Estas instrugoes podem ser divididas de acordo com aquilo que 
elas aumentam ou diminuem. 

A — Conteudo de um registrador de oito BITs 

30000 0C INC C 

30001 C? EET 

String: “0CC9P” 

A instrugao PRINT USR 30000 fornece 300001 como resultado, 
uma vez que o registrador C sofreu um acrescimo igual a um. Neste 
sentido, INC registrador pode ser entendido como semelhante em 
BASIC a instrugao: LET registrador = registrador + um. 

O que ocorre se o valor de C for 255? 

30000 0EFF CD 0,255 

30002 0C INC L 

30003 0600 LD 

30005 09 RET 

String: “0EFF0C0600C9P” 

A rotina acima mostra que o valor em retorno e igual a zero. 
Portanto, e possivel limpar o registrador com a instrugao INC 
registrador, desde que o valor anterior seja 255. 

Experimente a rotina abaixo: 


30000 

30002 

30006 

30005 


0E00 

0600 

0t> 

09 


L.D C : .0 
LD 8,0 
DEO C 
RET 


String: “0E0006000DC9P” 

Qual o resultado da instrugao PRINT USR 30000? Ela retorna com 
255, ou seja, se um registrador contem 255 (FF em HEX) apos a 
instrugao DEC registrador, e porque o seu valor anterior era zero. 
A tabela abaixo fornece o codigo em HEX destas instrugoes. 
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INC A 3C DEC A 3D 
INC B 04 DEC B 05 

INC C 0C DEC C 0D 

INC D 14 DEC D 15 

INC E 1C DEC E ID 

INC H 24 DEC H 25 

INC L 2C DEC L 2D 

Esta instrugao e semelhante em BASIC a: 

LET registrador = registrador - um. 


B - Conteudo de um registrador de 16 BITs 


30000 03 

30001 09 


I NO BO 
RET 


String: “03C9P” 

A rotina acima retorna com.o valor 30001 portanto, INC BC, 
acrescenta um ao enderego de retorno. Isto e feito aumentando-se o 
BYTE menos significative. Se este contem 255, o acrescimo e feito da 
seguinte maneira: o BYTE menos significativo e zerado, e o mais 
significativo e adicionado de um. 


30000 0B 

30001 09 


DEC BO 
RET 


“String”: “0BC9P” 

O resultado em retorno e evidentemente 29999. O processo aqui e 
similar ao anterior: se o BYTE menos significativo e nulo, ele passa a 
ser 255, e o mais significativo sofre um decrescimo de um. 

Escreva uma rotina onde BC tern valor zero e, em seguida, e 
implementada a instrugao DEC BC. Qual o resultado que voce obtem? 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


INC BC 03 
INC DE 13 
INC HL 23 
INC SP 33 
INC IX DD23 
INC IY FD23 

Estas instrugoes sao semelhantes em BASIC, respectivamente, a. 

LET registrador de 16 BITs = registrador de 16 BITs +1 
LET registrador de 16 BITs = registrador de 16 BITs -1 


DEC BC 0iB 
DEC DE IB 
DEC HL 2B 
DEC SP 3B 
DEC IX DD2B 
DEC IY FD2B 
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C - Conteudo de urn local na memoria 


30000 

30003 

30003 

30008 

30009 


213A75 
3E20 
323A75 


LD HL , 30010 
LD A,32 
LD (300:1.0),A 
t'NC (HL) 

RET 


“String”: 213A753E20323A7534C9P” 

Para variar o conteudo de A e testar o efeito sobre o conteudo da 
memoria, indicado pelo par de registradores HL, entre com o seguinte 
programa: 


10 INPUT X 
20 POKE 30004, X 
30 RANDUSR 30000 
40 PRINT PEEK 30010 
50 GOTO 10 


Escreva uma rotina, similar a dada acima, que utilize a instrugao 
DEC (HL). 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


INC(HL) 34 DEC (HL) 35 

INC (IX+dis) DD34N DEC (IX+dis) DD35N 

INC (IY+dis) FD34N DEC (IY+dis) FD35N 

(N e um numero em HEX no intervalo entre 00 e FF) 

Estas instrugoes sao semelhantes em BASIC, respectivamente, a: 

LET enderego = enderego + 1 
LET enderego = enderego - 1 


EXERCICIOS 

1) Elabore uma rotina que faga SCROLL ao contrario da tela toda. 

2) Repita os exercicios do presente capitulo variando as instrugoes. 
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CAPITULO V : 

GRUPO DE OPERATES ARITMETICAS E LOGICAS 


Neste capitulo, onde estudaremos as diversas instrugoes logicas e 
aritmeticas, voce entendera por que o acumulador desempenha um 
papel fundamental na programagao em linguagem de maquina. 
INSTRUCOES ARITMETICAS 

Atraves destas instrugoes, pode-se realizar operagoes aritmeticas 
entre os diversos registradores e o acumulador. Elas afetam o estado 
dos “FLAGs”, contudo, estes somente serao estudados no proximo 
capitulo. 

Cada exercicio ensina um tipo de instrugao e deve ser executado 
com o auxilio do computador. Para entrar com as rotinas em linguagem 
de maquina, utilize o mesmo programa de carregamento. 
EXERCICIOS ILUSTRATIVOS 
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PRINT USR 30000 retorna com 72. Experimente ultrapassar 255 
com o auxilio do seguinte programa: 


10 INPUT X 
20 INPUT Y 
30 POKE 30001.X 
40 POKE 30083.Y 
50 PRINT USR 30000 



Toda vez que se ultrapassa 255 ha um transbordamento (um 
overflow) e o resultado e subtraido de 256. 

Que instru^ao permite duplicar o valor contido num registrador, se 
ele estiver no intervalo entre 1 e 127? 

A tabela abaixo fornece o codigo em HEX destas instrusoes. 

ADD A,A 87 
ADD A,B 80 
ADD A,G 81 
ADD A,D 82 
ADD A,E 83 
ADD A,H 84 
ADD A,L 85 

Estas instru^oes sao semelhantes em BASIC a: 

LET acumulador = acumulador + registrador 

II - Adicionar com “CARRY” o conteudo de um registrador, ao 
conteudo do acumulador 


3PI0Q0 

06FA 

LD B.23 

30002 

3E06 

1... D A > 6 

3 0 0 0 4 

88 

A [) U A l:> 

30005 

3E00 . 

LD A. B 

3B007 

8F 

ADC A.A 

30003 

41** 

LD C.A 

30009 

0600 

LD B. B 

30011 

C9 

Re i 


Na rotina acima, pode-se constatar que o valor colocado em A 
uitrapassou a 255; isto e, houve um transbordamento. Isto afeta o 
“CARRY FLAG”, (sinalizador de transporte), que fica igual a 1. 
Afirma-se que ele foi ativado (set). Com o auxilio do programa anterior 
pode-se variar os valores carregados em B e A, e constatar, atraves 
desta rotina, quando ocorre um “CARRY”, (um transporte) 
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A tabela abaixo fornece o codigo em HEX destas instrii^oes. 


ADC A,A 8F 
ADC A,B 88 
ADC A,C 89 
ADC A,D 8A 
ADC A,E 8B 
ADC A,H 8C 
ADC A,L 8D 

Observa^oes: 

a) estas instru$oes sao semelhantes em BASIC ao seguinte conjunto: 
LET acumulador = acumulador -I- registrador + “CARRY” 

LET “CARRY” =INT ((acumulador + registrador)/256) 

b) haduas instru^oes que controlamdiretamente o “CARRY FLAG”: 

— SCF (codigo em HEX: 37) - ativa o “CARRY FLAG”, isto e, ele 
fica igual a um; 

— CCF (codigo em HEX: 3F) - fornece o complemento do “CARRY 
FLAG”, ou seja, um menos o estado presente do “CARRY 
FLAG”. 


Ill - Subtrair o conteudo de um registrador, do conteudo do acumulador. 


Este e o seguinte exercicios sao complementares aos dois primei- 
ros. Portanto, utilize o programa dado naqueles exercicios paratestar 
as rotinas que serao oferecidas. 


30000 

30002 

30004 


30005 


300(90 

30008 


BE 10 
3E20 
91 
4 b 

0600 

C9 


I..D C. 16 
LD A.32 
SUB A.C 
LD C.A 
LD B.B 


.R E l 


Se o resultado foi um numero negativo, isto e, se ocorrer um 
“emprestimo”, o resultado e somado a 256. A instru^ao SUB A torna 
o conteudo do acumulador igual a zero. 

A tabela abaixo fornece o codigo em HEX destas instru^oes. 

SUB A 97 
SUB B 90 
SUB C 91 
SUB D 92 
SUB E 93 
SUB H 94 
SUB L 95 
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Estas instrugoes sao equivalentes em BASIC a: 

LET acumulador = acumulador - registrador 

IV - Subtrair com “CARRY” o conteudo de um registrador, do 
conteudo do acumulador 


30800 

0E20 

LD 0,32 

30002 

3E06 

LD A, 6 

30004 

99 

SBC A,0 

38005 

3E00 

LD A, 0 

30007 

8F 

ADC A,A 

30008 

4F 

LD 0,A 

30009 

0600 

LD B, 0 

30011 

09 

RET 


Variando os valores carregados no registrador C e no acumulador, 
obtem-se um, se C for maior do que A (isto e, se houver um 
emprestimo e o “CARRY FLAG” for ativado); e zero, se C for menor 
ou igual a A (ou seja, se nao houver emprestimo e o “CARRY FLAG” 
for restaurado). 

Por que a rotina acima nao controlaria o “CARRY FLAG” se a 
instru$ao LD A, 0 fosse substituida por SUB A? 

A tabela abaixo fornece o codigo em HEX destas instru^oes. 

SBC A,A 9F 
SBC A,B 98 
SBC A,C 99 
SBC A,D 9A 
SBC A,E 9B 
SBC A,H 9C 
SBC A,L 9D 

V — Adigao e Subtra^ao envolvendo registradores de 16 BITs 

Neste tipo de instru^ao, o par de registradores HL toma o lugar do 
acumulador. 

Adigao sem “CARRY” 


30000 

012909 

LD 80,2345 

38003 

21SD45 

LD HL,17305 

30006 

09 

ADD HL, BO¬ 

30007 

44 

LD B,H 

30088 

4D 

LD C,L 

30009 

09 

RET 


O programa abaixo permite variar os valores colocados em BC e HL. 
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INPUT C 
INPUT 8 
INPUT L 
INPUT H 
POKE 30081,0 
POKE 30002,8 
POKE 38804,L 

PHkT "‘tWWR'-i W 

PRINT"peek 30001+256*-PEEK 30002? 

" ? PEEK 30004+256* P E E K 30005?" * " ?-USR' 30000 
GOTO 10 


O que acontece se o valor da soma ultrapassar a 65535? 

A tabela abaixo fornece o codigo em HEX destas instru<?6es. 

ADD HL, BC 09 
ADD HL, DE 19 
ADD HL, HL 29 
ADD HL, SP 39 

Estas instru$oes sao semelhantes em BASIC a: 

LET par de registradores HL=par de registradores HL 

.+ par de registradores de 16 BITs 


Adi$ao com “CARRY” 


30000 

110000 

LD DE,8 

30003 

210008 

LD HL.,0 

30006 

ED5A 

ADO HL,DE 

30008 

3E00 

L D A, 0 

3001 0 

8F 

ADC A,A 

30011 

4F 

LD 0, A 

38012 

@600 

LD B, 0 

30014 

09 

RET 


O resultado de PRINT USR 30000 sera zero, se nao houver um 
transbordamento (isto e, o resultado nao for superior a 65535); caso 
contrario, sera um. 
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Subtra^ao com “CARRY” 

Nao existe subtra§ao sem CARRY 

38000 1:1.0000 

30003 2.1.0000 

30006 


38008 

30010 


30012 

30014 


ED52 

3E00 

SF 

4F 

0600 


LD DE,0 
LD HL , 0 
SBC HL , DE 
L.. D A , 0 
ADC A,A 
LD C, A 
LD B 0 
RET 


O resultado de PRINT USR 30000 sera zero, se DE for menor ou 
igual a HL; se diferente, sera um: houve um emprestimo. 

A tabela abaixo fornece o codigo em HEX dos dois ultimos tipos 

de instru?ao. 


ADC HL, BC ED4A 

ADC HL, DE ED5A 

ADC HL, HL ED6A 

ADC HL, SP ED7A 


SBC HL, BC ED42 

SBC HL, DE ED52 

SBC HL, HL ED62 

SBC HL, SP ED72 


VI — Adigao e Subtra S ao envolvendo o acumulador e uma 
localidade na memoria, 

Pode-se realizar operates aritmeticas entre o acumulador e uma 
localidade na memoria aponta4a por HL. 


30000 


30006 

30005 


213A75 

3E00 


41" 

0600 


LD HL,30010 
LD A ,0 
ADD .A? (HL) 
LD C_, A 
LD B,8 
RET 


Teste esta rotina a partir do seguinte programa: 

10 INPUT X 

28 INPUT Y 

30 POKE 30004 : .X 

40 POKE 30018,Y 

50 PRINT PEEK 30084?" ' '■ 

"SOMA ~ "? USR 38008 

68 GOTO 10 


EK 30010? 
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Tambem e possivel realizar adigao com “CARRY”. 


30000 

213F75 

LD HL,3001 

30003 

3E00 

LD A,8 , 

30005 

8E 

ADC A,(HL) 

38006 

3E00 

LD A, 8 

30008 

8F ' 

ADC A, A 

38009 

4F 

LD C, A 

30018 

0680 

LD B, 0 

30012 

c? 

RET 


Para testa-la, altere as linhas 40 e 50 do programa anterior para: 

40 POKE 30015,Y 

58 PRINT PEEK 30004?" " ?PEEK 30815? 

" CARRY- "? USR 30000 


Tambem e possivel subtrair com ou sem “CARRY” o acumulador 
de uma localidade na memoria. Escreva, como exercicio, rotinas que 
utilizam este tipo de instrugao. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


ADD A, (HL) 

86 

ADC A, (HL) 

8 E 

SUB (HL) 

96 

SBC A, (HL) 

9E 


VII — Adigao e Subtragao de constantes ao acumulador 

Tambem se pode realizar operagoes aritmeticas entre o acumula¬ 
dor e constantes. 


30888 

3E00 

LD A,0 

30882 

CE.1.6 

ADC A,22 

38804 

4F 

LD C,A 

30805 

0600 

LD B, 0 

30087 

C9 

RE f 


Escreva um programa em BASIC que permita variar os valores 
colocados no acumulador e na instrugao de ADC A, N. Elabore uma 
rotina que utilize a instrugao SBC A, N. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 

ADD A,N C6 N 

ADC A, N CE N 

SUB N D6 N 

SBC A, N DE N 
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(N e um numero em HEX no intervalo entre 00 e FF) 


VIII — Instrugoes de Comparagao 

O valor presente no acumulador pode ser comparado com valores 
carregados em registradores de oito BITs, ou com valores presentes 
em localidades na memoria, ou, finalmente, com constantes atribuidas 


acumulador. 


mas afeta 

o registrador de 

“FLAGs”, o qual sera 

proximo capitulo. Comparar significa subtrair algo do 

30800 

060 A 

LD B , 10 

38082 

3 El 4 

LD A,20 

30004 

B o 

CP 8 

30805 

3E00 

LD A , 0 

30007 

CE00 

ADC A : ,0 

30089 

4F 

LD L ;i A 

300:1.8 

0600 

LD 8,0 

30012 

C? 

RET 


A rotina acima testa o “CARRY FLAG”. Elaretorna 1, quando o 
valor em B e maior do que o valor contido em A, e zero, quando e 
menor ou igual ao presente em A. Escreva um programa que permita 
testar esta rotina para diferentes valores de A e de B. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


CP A BF 
CP B B8 
CP C B9 
CP D BA 
CP E BB 
CP H BC 
CP L BD 

INSTRUCOES LOGICAS 

As instrugoes logicas envolvem o acumulador e valores presentes 
nos registradores de oito BITSs, ou em localidades na memoria, ou 
constantes atribu'das pelo programador. Elas estao baseadas na logica 
de BOOLE. Antes de examina-las, vamos estudar os tres tipos de 
operagoes logicas presentes no uso destas instrugoes. As operagoes 
sao: 

a) operagao AND 

b) operagao OR 

c) operagao XOR 
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CP (HL) BE 
CP N FE N 
CP(IX+dis) DDBE N 
CP (IY+dis) FDBE N 


OPERACAO AND 

Suponhamos, para simplificar, que as palavras do nosso proces- 
sador tern comprimento igual a 1 BIT, isto e, variam no intervalo de 0 a 
1. Se aplicarmos a operagao AND a duas palavras quaisquer, teremos 
o seguinte resultado: 

0 AND 0 = 0 
0 AND 1 =0 
1 AND 0 = 0 
1 AND 1 = 1 

Em outras palavras, so obteremos 1 quando ambas as palavras 
estiverem no estado um. Caso contrario, o resultado sera zero. 

OPERACAO OR 

Partindo das mesmas premissas citadas no caso anterior, teremos: 

0 OR 0 = 0 
0 OR 1 = 1 
1 OR 0 = 1 
1 OR 1=1 

Ou seja, o resultado sera sempre um quando pelo menos um dos 
termos estiver no estado um; caso contrario, sera zero. 

OPERACAO EXCLUSIVE OR - XOR 

Partindo ainda das mesmas premissas, teremos: 

0 XOR ® = 0 
0 XOR 1 = 1 
1 XOR 0=1 
1 XOR 1 = 0 

Portanto, o resultado sera igual a zero todas as vezes que ambos 
os termos estiverem no mesmo estado; caso contrario, sera um. 

Podemos passar agora ao estudo das diversas instrugoes que 
utilizam essas operagoes logicas. 

1 - Instrugoes que utilizam a operagao booleana AND 


30800 

3 El 00 

LD A, 0 

30082 

8600 

LD B, 0 

30004 

A0 

AND B 

30085 

4F 

LD C, A 

30006 

0600 

LD B, 0 

30008 

C9 

RET 


49 



Note que a instrugao AND B afeta apenas o conteudo do 
acumulador; o valor presente em B permanece o mesmo. Para tornar 
bastante claro o que esta instrugao realiza, entre com o seguinte 
progra'ma: 

3.0 INPUT X 
20 INPUT Y 
30 POKE 3000I.-X 
40 POKE 30003,Y 
50 LET A--X 
55 GOSUB 3.00 
60 LET A--Y 
65 GOSUB 3.00 
70 LET A-USR 30000 
75 GOSUB 3.00 
80 PRINT 
90 GOTO 10 

100 PRINT A r TAB 3.0? " : " 

3.05 FOR N-7 TO 1 STEP ~1 
3.10 LET D~2**N 

115 PRINT CHR$(28 + INT(A/D)) i 

120 LET A~A~ INT <A/D)*D 

125 NEXT N 

3.30 PRINT A 

135 RETURN 

Ele permite controlar os valores presentes em A e B. Alem disto, 
imprime estes valores em BINARIO, assim como o resultado da 
instrugao AND B (em decimal e em BINARIO). 

Observances: 

a) a instrugao AND A nao altera o conteudo do acumulador, mas 
reajusta o “CARRY FLAG”; 

b) as instrugoes AND 0F (15 em decimal) e AND F0 (240 em decimal) 
servem, respectivamente, para zerar os quatro BITs mais significa- 
tivos e os quatro BITs menos significativos presentes no acumula¬ 
dor, e para manter inalterada a parte restante. Por exemplo: 

123 = BIN 01111011 123 = BIN 01111011 

15 = BIN 00001 111 240 — BIN 1110000 

AND 0F = BIN 00001011 AND F0 = BIN 01110000 
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c) a instrugao AND e utilizada para zerar os BITs escolhidos pelo 
programador. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


AND A A7 
AND B A0 
AND C A1 
AND D A2 
AND E A3 
AND H A4 
AND L A5 


AND N E6 N 


AND (HL) A6 
AND (IX+dis) DDA6N 
AND (IY-hdis) FDA6N 


H Instrugoes que utilizam a operagao booleana OR 


30000 

30002 

30004 

30005 

30006 


3E00 

0600 

B0 

4l r 

0600 

C9 


LD A0 
LD B, 0 
OR B 
LD C : ,A 
LD B, 0 
RET 


Teste esta rotina a partir do programa anterior. 

Observances: 

a) a instrugao OR A nao altera o conteudo do acumulador, mas 

restaura o “CARRY FLAG”; 

b) a instrugao OR 80 (128 em decimal) ira sempre ativar o BIT mais 
significativo presente no acumulador, isto e, BIT 7 = 1; 

c) a instrusao OR e utilizada para ativar os BITs escolhidos pelo 

programador. . 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


OR A B7 
OR B B0 
OR C B1 
OR D B2 
OR E B3 
OR H B4 
OR L B5 


OR N F6 N 


OR(HL) 

OR(IX-i-dis) 

OR(IY-i-dis) 


B6 

DDB6 N 
FDB6 N 


III - Instrugoes que utilizam a instrugao booleana XOR 
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30000 3EE00 LD A-.0 

30002 0600 1-15 B ? 0 

30004 AB XOR B 

4F LD C,A 

30006 0600 L t> B0 

30008 C9 BET 


Teste esta rotina do mesmo modo que a anterior. 

Observances: 

a) a instrunao XOR A limpa o acumulador e restaura o “CARRY 
FLAG”; 

b) A instrugao XOR 0 deixa o conteudo do acumulador inalterado, mas 
restaura o “CARRY FLAG”; 

c) esta instru^ao e utilizada, como veremos mais tarde, para testar o 
conteudo de um BIT. 

A tabela abaixo fornece o codigo em HEX destas instru^oes. 


XOR A 

AF 

XOR N EE N XOR (HL) 

AE 

XOR B 

A8 

XOR(IX-i-dis) 

DDAEN 

XOR C 

A9 

XOR(IY-i-dis) 

FDAEN 

XOR D 

AA 



XOR E 

AB 



XOR H 

AC 



XOR L 

AD 




(onde N e um numero em HEX no intervalo entre 00 e FF) 


Exerricios: 

1. Escreva uma rotina que imprima na tele o alfabeto de A ate Z. 

2. Escreva uma rotina que efetue a soma de N numeros, e depois teste 
se ela ultrapassa ou nao 65535. 

3. Escreva uma rotina que limpe uma linha na tela escolhida por voce. 
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CAPITULO VI: 

GRUPO DE SALTO, CHAMADA E RETORNO 


Neste capitulo, antes de examinarmos o novo grupo de instrugoes, 
vamos estudar as convengoes complemento de dois e o registrador de 
“FLAGs”. 

COMPLEMENTO DE DOIS 

Podemos utilizar os binarios compreendidos entre 0000 e 1111 
para representar os numeros decimais entre 7 e -8. 

A tabela abaixo ja foi estudada. 



0 3.3.3. 
013.0 
0 3.03. 
0 . 1.00 
003 . 3 . 
@03.0 
0003. 
0000 


Para determinar o .complemento de dois de cada um desses 
numeros achamos o complemento do numero binario (no caso presen¬ 
te, estamos trabalhando com quatro BITs) e somamos a ele 0001. 
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Por exemplo, queremos determinar o complemento de dois de um 
com quatro BITs. Para isto, precisamos executar os seguintes passos: 

a) tomamos a representapao positiva de 1, isto e, 0001; 

b) achamos o complemento de 0001, ou seja, 1110 (para encontrar o 
complemento basta substituir zero por um, e vice-versa); 

c) somamos tal complemento ao resultado 0001, o que resulta 1111. 

Portanto, 1111 e complemento de dois com quatro BITs de 0001. 
Para somar, e suficiente atentar para o quadro abaixo: 


0 + 0 = 0 
1 + 0=1 
0+1 = 1 

l + l = 0 e leva 1 para a coluna seguinte. 

Experimente encontrar o complemento de dois com quatro BITs de 
sete. 

Passos: 

a) 7 = 0111; 

b) complemento de 7 = 1000; 

c) somado com 0001, resulta 1001. 

Logo, -7 representado com 4 BITs e igual a 1001. 

A tabela abaixo fornece os numeros entre -1 e -8. 


-1 : 1111 
-2 ; 1110 
-3 ■ 1101 
-4 = 1100 
-5 •• 1011 

-6 : . 1010 
-7 : 1001 
~8 : 1000 

Constate que os numeros positivos tern o BIT mais significative 
igual a zero, enquanto os negativos, igual a um. 

Contudo, quando se procura obter o complemento de dois de 1000 
obtem-se 1000 — ocorreu um transbordameqto (um overflow). Ora, isto 
nao poderia ocorrer: o complemento de dois de um numero negativo 
deve ser um numero positivo. O que aconteceu? 

Isto ocorreu porque so podemos representar com quatro BITs 
numeros no intervalo entre -8 e 7. Logo, 8 nao pode ser representado 
na convenpao complemento de dois com apenas quatro BITs; sao 
necessaries mais BITs. Com oito BITs, ampliamos o intervalo em que 
podemos representar numeros atraves da convenpao complemento de 
dois. 


Nao e dificil entender por que, com oito BITS, o maior numero 
positivo e 127. Como ele e positivo, o seu BIT mais significativo e igual 
a zero. Portanto, o maior numero com oito BITs em representapao 
binaria e 01111111: ( 127 em decimal). O complemento de 127 e 
10000000 que, somado com 00000001, resulta 10000001 (-127 em 
decimal). O maior numero negativo e 10000000, isto e, -128 em 
decimal. Logo, com oito BITs podemos representar numeros entre 
-128 a 127, ou seja, um total .de 256 representapoes. 

Com 16 BITs podemos utilizar a convenpao de dois para represen¬ 
tar numeros dentro de qual intervalo? 

As considerapoes acima devem ter evidenciado a necessidade de 
se especificar o numero de BITs, quando se trabalhar com a convenpao 
complemento de dois. 

A rotina abaixo encontra o complemento de dois (com oito BITs). 


30000 

3E00 

LD A;. 0 

30002 

2F 

CPL 

30003 

30 

INC A 

30004 

4F 

LD 0, A 

30005 

0600 

LD B, 0 

30007 

09 

RET 


Entre com o seguinte programa, visando obter os numeros 
negativos entre -1 e -128. 

10 FOR D-.1 TO .128 
20 POKE 30001jD 
30 LET N-USR 30000 
4@ PRINT -256+N?" = "? 

50 G0S1JB. 100 
60 NEXT D 

100 FOR S~7 TO 1 STEP -1 

105 LET X=2**S 

110 PRINT CHR$( 28+INT(N/X))? 

115 LET N-N- INT(N/X)*X 
120 NEXT S 
125 PRINT N 
130 RETURN 

Na rotina acima pode-se substituir as instrupoes CPL e INC A por 
NEG (codigo em HEX-ED44). 0 resultado sera identico. Experimen¬ 
te. No Apendice 5, encontra-se em HEX a tabela produzida pelo 
programa acima. 
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REGISTRADOR DE “FLAGS” 


O registrador de “FLAGs” fornece informagoes relevantes sobre 
as condigoes internas do microprocessador. Ele possui oito BITs, 
embora.sejam usados apenas seis: os BITs 5 e 3 tern o conteudo 
sempre igual a zero. 

Vamos descrever os diversos “FLAGs” (sinalizadores), partindo 
do BIT 7. 

BIT 7 — Controla o estado do sinal. Se o numero for positivo, entao 
BIT 7 sera igual a zero; caso contrario, ele sera um. Portanto, 
a “FLAG” de sinal opera baseada na convengao complemen- 
to de dois. 

BIT 6 — Controla o estado de zero. Se o numero presente for zero, 
entao BIT 6 sera igual a um. Se o numero presente for 
diferente de zero, entao BIT 6 sera igual a zero. Logo, o 
“ZERO FLAG” atua de forma inversa a que seria esperada. 
BIT 5 — Nao e usado. 

BIT 4 — Controla se ocorre ou nao um transbordamento no BIT 3. O 
“HALF CARRY FLAG” e usado pela CPU, e o seu estado 
nao pode ser testado por nenhuma instrugao a disposigao do 
programador. 

BIT 3 — Nao e usado. 

BIT 2 — Controla duas coisas distintas, dependendo da natureza da 
operagao efetuada. Se ela for logica, o controle sera exercido 
sobre o estado de paridade — se ele e impar ou par — isto e, 
se o numero de zeros (ou de uns) e impar ou par. Se a 
operagao for aritmetica, ela controlara se houve ou nao um 
transbordamento, baseada na convengao complemento de 
dois. A “Parity/Overflow Flag” sera zero quando a paridade 
for impar ou quando nao ocorrer um transbordamento; caso 
contrario, ela sera um. 

BIT 1 — Controla a ocorrencia de operagoes de subtragao. E usada 
pela CPU e, do mesmo modo que o BIT 4, nao e acessivel ao 
programador. Quando ocorrer uma subtragao BIT 1 sera 
igual a 1; caso contrario BIT 1 sera igual a zero. 

BIT 0 — Controla se ocorreu ou nao um “CARRY”. Foi examinado no 
capitulo anterior. 

I — Operagoes de Salto 

Sao instrugoes semelhantes, dentro de certos limites, ao GOTO do 
BASIC. Contudo, a forma de enderegamento e diferente, podendo ser 
de dois tipos: 

a) absoluto; 

b) relativo. 
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Em ambos os tipos podemos fixar condigoes para alterar o PC 
(contador de programa). Esta e uma das utilidades do registrador de 
“FLAGs” — permitite controlar em que condigoes o PC deve ser 
modificado. 

SALTOS ABSOLUTOS 

a) Sem condigoes — neste caso, toda vez que a rotina atingir esta 
instrugao, o PC sera alterado para o enderego indicado. 


30000 

0600 

LD 8,0 

30802 

0E05 

LD C, 5 

30004 

C33A75 

JP 3001 

30007 

0E10 

LD C,16 

30009 

09 

RET 

300X0 

09 

RET 


PRINT USR 3 0000 resultara em 5, e nao em 16, devido a 
instrugao de salto. 

(codigo em HEX: C3NN, onde NN e um enderego no intervalo 
0000 a FFFF) 

b) Condicionados - o salto so sera efetuado se a condigao estabelecida 
for preenchida; caso contrario, a instrugao sera ignorada. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 
JP NZ, NN; C2NN - salta, se o ultimo resultado nao for nulo. 
JP Z, NN: CANN - salta, se o ultimo resultado for nulo. 

JP NC, NN: D2NN - salta, se no ultimo resultado nao ocorrer um 
“CARRY”. 

JP C, NN.’DANN - salta, se no ultimo resultado ocorrer um 
“CARRY”. 

JP PO, NN: E2NN - salta, se no ultimo resultado nao ocorrer um 
transbordamento e a paridade for impar. 

JP PE, NN:EANN - salta, se no ultimo resultado ocorrer um trans¬ 
bordamento e a paridade for par. 

JP P, NN! F2NN - salta, se o ultimo resultado for positivo. 

JP M, NN.'FANN - salta, se o ultimo resultado for negativo. 

Para testar estas diversas instrugoes, vamos dar um modelo de 
rotina e um programa em BASIC para cerca-la. Procure modifica-lo 
de modo a testar o maior numero possivel de instrugoes. 


30000 

0E00 

LD 0,0 

30002 

sit t).8 

LD A0 

30004 

B9 

CP 0 

30005 

023375 

JP NZ,3 

30008 

0600 

LD B, 0 

30010 

09 

RET 
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30011 

300:1.3 


5 


0600 

0EFF 


C9 


LD B,0 
LD C 2 
RET 



Esta rotina resultara em 255 quando a instrugao de salto for 
executada; caso contrario, ela retornara o valor colocado no 
registrador C. 


10 INPUT 
20 INPUT 
30 POKE 



X 


40 POKE 
30 PRINT 
68 GOTO 


03, Y 

^ » )i (i » y v it 

. 1 . 0 


H 


} USR 30008 


No exemplo fornecido, se X for igual a Y, o valor em retorno 
sera X. Caso contrario, sera 255. Para alterar a rotina, basta 
modificar o enderego 30005. 

SALTOS RELATIVOS 

A grande vantagem em se usar saltos relatives esta na possibilida- 
de de alterar-se o enderegamento da rotina em linguagem de maquina 
sem a necessidade de adapta-la. 

a) sem condigdes — Toda vez que a rotina atingir este tipo de ins 
trugao, o PC sera incondicionalmente alterado. O novo enderego 
sera determinado pela magnitude do deslocamento, fixado na 
convengao complemento de dois. Portanto, e possivel saltar-se ate 
129 enderegos para frente ou 126 enderegos para tras. Note que, 
quando o salto for para frente, o novo enderego sera o enderego do 
ultimo BYTE da instrugao, somado ao deslocamento mais um. No 
exemplo abaixo: 

ultimo BYTE da instrugao — enderego -30005 
deslocamento -2 BYTEs 

novo enderego=30005 -i- 2 -i- 1, isto e, o enderego 30008. 

Quando o salto for para tras, o novo enderego sera o enderego 
do ultimo BYTE, subtraido do deslocamento. Logo, JR-1 levara a 
uma repetigao infinita. Em outras palavrajs, gastamos dois desloca- 
mentos quando queremos ir para tras ; por conseguinte, o maximo de 
deslocamentos para tras e 126. 


30000 

0600 

LD B ,0 

3G002 

0E03 

LD C,C 

30004 

1302 

JR 2 

30006 

0E10 

LD 0,1 

30003 

C9 

RET 


PRINT USR 30000 retornara com 5, e nao com 16. Note que a 
instrugao que utiliza salto relativo e menor do que a de salto 
absoluto. Ela tern um comprimento igual a dois BYTEs. 

b) condicionados — A tabela abaixo fornece o codigo em HEX destas 
instrugoes. 


JR NC, dis 30N JR NZ, dis 20N 
JR C, dis 38 N JR Z, dis 28 N 

(N e um numero em HEX baseado na convengao complemento de dois) 

c) Tipo especial de salto relativo — Tambem e possivel usar iijna 
instrugao de salto relativo que simultaneamente ira alterar o valor 
presente no registrador B. Cada vez que a instrugao for executada, 

B sofrera um decrescimo de um. A instrugao sera repetida ate que B 
seja zero. 

(codigo em HEX— DJNZ, dis: 10 N, onde N eumnumeroem HEX 
baseado na convengao complemento de dois.) 

As instrugoes de salto relativo estao ilustradas pelas rotinas 
abaixo. Procure compreende-las. 

ROTINA 1: inverte os caracteres presentes na tela, desde que 
eles estejam no intervalo entre 0 e 63. 


30000 

2A0C40 

LD TIL. (16396) 

30003 

0C16 

LD B.,22 

30005 

23 

INC HL 

30006 

7E 

LD A., <HL> 

30007 

FE 76 

CP 118 

30009 

2805 

JR Z,5 

300.1.1 

C6B0 

ADD A,128 

30013 

77 

LD (TIL).,A 

30014 

18F5 

JF( -*11 

30016 

77 

LD (HL),A 

30017 

10F2 

DJNZ -14 

30019 

C9 

RET 


Entre com RAND USR 30000 e a tela ficara imeditamente 
invertida. Escreva uma outra rotina que remova a restricao acima. 


ROTINA 2: possibilita um SCROLL lateral, da esquerda para a direita. 
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30000 

2A0C40 

LD HL,(16396) 

3O0O3 

010100 

LD 8C,1 

30006 

09 

ADD HL.,BC 

30007 

1E16 

1 n f oo 

30009 

E5 

PUSH HL 

30010 

@61F 

LD B, 31 

30012 

7E 

LD A, (HL.) 

30013 

n 7. 

Am W 

INC HL 

30014 

56 

LD D , < HL > 

30015 

77 

LD < HL),A 

30016 

7 A 

LD A,D 

30O17 

10FA 

DJNZ -6 

30019 

C1 

POP BC 

30020 

02 

LD (BC) :> A 

30021 

23 

INC HL 

30022 

W 

INC HL 

30023 

10 

DEC E 

30024 

20EF 

JR NZ,-17 

30026 

C9 

RET 

Para testar ; 

a rotina 2, entre 

com o seguinte programa: 

10 LET A$ 

“"LINGUAGEfl 

DE MAQUINA" 

20 PRINT 

A$ 


30 RAND U 

SR 30000 


40 GOTO 30 


Procure escrever uma 

outra rotina, baseada nesta, que faca um 

SCROLL lateral da direita para a esquerda. 

ROTINA 3: possibilita colocar em qualquer lugar da tela, com o 

tamanho desejado, um conjunto de caracteres, Pode ser 

usada para limpar a tela no local que o programador 

deter minar. 


30000 

2A0C40 

LD HL,(16396) 

30003 

0 K 

W 

INC HL 

30004 

1600 

LD D,0 

30006 

3E00 

LD A, 0 

3000S 

BA 

CP D 

30009 

3006 

JR NC, C 

30011 

012100 

LD BC,33 

30014 

09 

ADD HL,BC 
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30015 

1814 

JR 20 

30017 

0620 

LD B,32 

30019 

3E00 

LD A ,0 

30021 

B8 

CP B 

30022 

3809 

JR C, 9 

30024 

3E00 

LD A, 0 

30026 

B8 

CP B 

30027 

3004 

JR NC,4 

30029 

7E 

LD A, (HL.) 

30030 

C600 

ADD A,0 

38032 

77 

LD (HL), A 

30033 

23 

INC HL 

30034 

10EF 

DJNZ -17 

30036 

•TV! 

A« 

INC HI¬ 

30037 

15 

DE C D 

30038 

20DE 

JR NZ,—34 

30040 

C9 

RET 


O programa abaixo vai ajuda-lo a compreender a rotina 
3. 


PRINT AT 0,5?"C0QRDENADA8" 

PRINT AT 1,0?"LINHA INICIAL - "? 

INPUT X ‘ 

IF XX?5 THEN GOTO 20 
PRINT X 

PRINT AT 2,0? "NUI1ER0 DE L.INI-1 AS = "? 

INPUT -XI 

IF X1XX+1) THEN GOTO 40 
PRINT XI 

PRINT AT 3, 0? "COLUNA INICIAL » "? 

INPUT Y 

IF (33-YX1 THEN GOTO 60 
PRINT Y 

PRINT AT 4,0? "NIJMERO DE COLIJNAS - " ? 

INPUT Y1 

IF <Y+Y1)>=33 THEN GOTO SO 
PRINT Y1 

PRINT AT 5,0?"NUMERO DO CARACTERE DESEJADO 
INPUT S 
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105 IF 8>65 AND SCI 28 AND 8; 
110 POKE 30005,X 
115 POKE '30007,XI 
120 POKE 30028,<33-Y> ■ 

125 POKE 30025,(33-Y-Y1) 

130 POKE 30031,3 
135 CLS 

160 RAND USR 30000 


192 THEN BOTO 


II - Instrugoes de chamada (CALL) 

Sao instrugoes semelhantes dentro de certos limites, ao GOSUB 
em BASIC. Da mesma forma que a instrugao de SALTO, ha dois tipos 
de chamada: 


a) incondicionada; 

b) condicionada. 


CHAMADA INCONDICIONADA 

Toda vez que o programa em linguagem de maquina encontrar este 
tipo de instru 9 ao, haver a uma altera 9 ao no PC. Contudo, o seu valor 
anterior sera guardado no “STACK”. Logo, toda vez que se chamar 
uma sub-rotina, o SP (STACK POINT) sofrera urn decrescimo de dois. 
Assim que for encontrada a instrugao “RETURN”, o endere^o sera 
retirado do “STACK”, e o programa retornara a este endere 9 o. 

Um exemplo deste tipo de instru 9 ao foi dado no capitulo inicial 
deste livro. Nele, chamavamos uma rotina presente no ROM, que 
possibilitava imprimir um caractere, cujo codigo era guardado no 
acumulador. Antes de aprendermos como e possivel imprimir novas 
coisas na tela, vamos examinar duas outras rotinas presentes no ROM. 


30000 

38003 

30004 

30005 

30006 
30003 

30011 

30012 
30014 


CDBB02 

44 

4D 

-> p 

A.. W 

28F8 

CDBD07 

4E 

0600 

C9 


CALL 699 
LD B, H 
L.D C, L 
INC L 
JR Z,-8 
CALL 1981 
LD C, < HL) 
LD B, 0 
RET 


Teste a rotina acima com o seguinte programa: 

LET A$= CHR$(USR 30000) 
20 PRINT A$ 

30 GOTO 10 
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Ele permite-lhe saber qual tecla foi acionada. A primeira rotina no 
ROM coloca em HL o codigo da tecla acionada. A segunda descodifica 
este valor e guarda o codigo do catactere em (HL). 

CALL CONDICIONADO 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 
CALL NZ,NN: C4NN — a rotina sera chamada, se o ultimo resultado 
for diferente de zero. 

CALL Z,NN: CCNN — a rotina sera chamada, se o ultimo resultado 
for igual a zero. 

CALL NC,NN : D4NN — a rotina sera chamada, se no ultimo 
resultado nao ocorrer um “CARRY”. 

CALL C,NN : DCNN — a rotina sera chamada, se no ultimo resultado 
ocorrer um “CARRY”. 

CALL PO,NN : E4NN — a rotina sera chamada, se no ultimo 
resultado nao ocorrer um transbordamento ou se a paridade for impar. 
CALL PE,NN : ECNN — a rotina sera chamada, se no ultimo 
resultado ocorrer um transbordamento ou se a paridade for par. 
CALL F,NN : F4NN — a rotina sera chamada, se o ultimo resultado 
for positivo. 

CALL M,NN : FCNN — a rotina sera chamada, se o ultimo resultado 
for negativo. 

Podemos testar estas diversas instru 9 oes atraves da seguinte 
rotina: 


30000 

0600 

LD B ,0 

30002 

3E00 

LD A,0 

38004 

B8 

CP B 

30005 

C4007D 

CALL NZ 

30008 

0600 

LD B, 0 

30010 

4F 

LD C, A 

30011 

C9 

RET 


No endere 90 32000 coloque a seguinte sub-rotina: 


32000 

30002 

32805 


3E0D 

CD0SBS 

C9 


LD A ,.13 
CALL 2056 
RET 


Escreva um programa em BASIC que permita variar os valores 
colocados em A e B, assim como variar o tipo de condi 9 &o imposta 
para chamar a rotina presente em 32000. Se esta for chamada, PRINT 
USR 30000 imprimira $, seguido do valor presente em A; caso 
contrario, apenas este ultimo retornara. 
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Ill — InstruQoes de Retorno 

Alem do retorno incondicional RET (codigo em HEX: C9), ja 
utilizado inumeras vezes, ha retornos condicionados. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


RET 

NZ 

C0 

RET 

Z 

C8 

RET 

NC 

D0 

RET 

C 

D8 

RET 

PO 

E0 

RET 

PE 

E8 

RET 

P 

F0 

RET 

M 

F8 


A rotina abaixo possibilita colocar na tela uma string com o 
tamanho desejado. 


30000 

El 

POP HL 

30001 

7E 

LD A 3 (HL> 

30002 

9 x 

a\+ 

INC HL 

30003 

E5 

PUSH HL 

30004 

FE43 

CP 67- 

30006 

CS 

RET Z 

30007 

CD 0808 

CALL 2056 

30010 

18F4 

JR -12 

30012 

CD3075 

CALL 30000 


Observances: 

a) a rotina chamada no endereno 30000 contem 12 BYTES — vai desde 
a instrugao POP HL ate a instrunao JR F4; 

b) esta rotina esta no endereno 30012; portanto, para chama-la no 
BASIC, digite RAND USR 30012; 

c) a instrugao POP HL aponta para o enderego logo apos a instrugao 
CALL 30000; logo, e exatamente a partir dai, no endere^o 30015, 
que se iniciam os dados; 

d) nao e necessario salvar os parametros antes de chamar a rotina no 
ROM, porque as instru^oes POP HL e PUSH HL fazem exatamen¬ 
te isto; caso elas nao estivessem presentes, seria necessario trocar o 
con junto principal pelo alternativo, antes de chamar a rotina 
presente no endere^o (0808 em HEX) 2056. 

Coloque no endere^o 30015 a seguinte string: 


STRING * ”80883081AEB3AC8AA6ACAAB 
80B2A686AEB3A680888043C9” 


2B0A9AA 


O que se obtem quando se digita RAND USR 30012? 


IV - Sub-rotinas de “RESTART” 

Essas rotinas estao colocadas em lugar fixo no ROM: nos 
endere^os 00, 08, 10, 18, 20, 28, 30 e 38 (em HEX). O seu conteudo 
depende do fabricante. No caso presente, elas fazem o seguinte: 
RST 00 — e ativada quando se liga o computador; calcula qual o 
espa$o dispomvel no RAM e confere valores as variaveis 
do sistema; a digita^ao de RAND USR 0 equivale a 
desligar e religar o aparelho. 

RST 08 — rotina de erro; fornece o codigo do erro cometido. 

RST 10 — coloca na tela o caractere cujo codigo esta no acumulador. 
RST 18 — coloca no acumulador o caractere cujo enderego e dado pela 
variavel do sistema presente no endere 90 16406. 

RST 20 — obtem o caractere seguinte ao apontado pela variavel do 
sistema presente no endere 90 16406. 

RST 28 — salta para a rotina de calculo em ponto flutuante. 

RST 30 — organiza o espa 90 na area de trabalho. 

RST 38 — rotina de interrup 9 ao, onde o registrador B guarda o numero 
da linha, e o registrador C, o numero da linha investigada. 

A investiga 9 ao detalhada destas rotinas e do ROM e feita em obra 
posterior, a ser publicada, de carater nao introdutorio. Contudo, 


experimente esta pequena rotina. 


30000 3E80 

LD A,128 

30002 D7 

RST 10H 

30003 C9 

RET 

A tabela abaixo fornece o codigo 

em HEX destas instrugoes. 


RST 00 Cl 
RST 08 CF 
RST 10 D7 
RST 18 DF 
RST 20 E7 
RST 28 EF 
RST 30 F7 
RST 38 FF 

EXERCICIOS: 

1. Procure realizar todas as sugestoes do exercicio que foram dadas 
neste capitulo. 

2. Colqque em linguagem maquina o programa em BASIC fornecido no 
EPILOGO. Sugestao de endere 9 o: 32000. 
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CAPITULO VII 

GRUPO DE ROTAQAO E DE “DESLOCAMENTO” 


I - INSTRUCAO DE ROTAGAO 

Nao iremos estudar, em detalhe, todos os tipos de rotagao. 
Gontudo, explicaremos, atraves de diversos exercicios, certas opera- 
goes de rotagao. 

Vamos supor que se deseje fazer uma rotagao circular para a 
esquerda, do registrador C, e que este contem o valor L 

B7 B6 B5 B4 B3 B2 B1 B0 

antes: 0000000 1 

depois: 0 0 0 0 0 0 1 0 

Pode-se constatar que o valor contido no BIT 0 passou para o BIT 

1. Qual a conseqiiencia disto? 

O valor presente no registrador C foi duplicado. Portanto, uma 
rotagao para a esquerda multiplica o valor presente no registrador. 
Contudo, o que ocorrera se o valor for superior a 127? 

Sabemos que um registrador de oito BITs pode ser carregado no 
maximo'com 255. Logo, se ele possuir um valor superior a 127, s a 
instrugao de rotagao para a esquerda acarretara um “CARRY”, e o 
valor em retorno sera o valor original multiplicado por dois, subtrafdo 
de 256. O valor do “CARRY” sera somado ou nao ao resultado, 
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dependendo do tipo de instrugao, ou seja, se ela for do tipo circular ou 
nao. 

Os exercicios abaixo ilustram as consideragoes feitas ate agora. 


EXERCICIOS ILUSTRATIVOS 


a) Rotagao circular para a esquerda 


30000 

0600 

30002 

0E00 

30004 

CB01 

30006 

3E00 

30008 

8F r 

30009 

323F7S 

30012 

C9 


LD B ? 0 
LD C ? 0 
RLC C 
LD A ? 0 
ADC A,A 
LD (30015),A 
RET 


PROGRAMA 


10 INPUT X 
20 POKE 30003.,X 
30 PRINT UBR 3006 
PEEK 30015 
40 GOTO 10 


?" CARRY 


Atraves da variagao do valor de X, pode-se constatar que, 
quando o “CARRY” e igual a um, o valor em retorno e o dobro, 
subtraido de 256, somado a um. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


RLC A CB07 
RLC B CB00 
RLC C CB01 
RLC D CB02 
RLC E CB03 
RLC H CB04 
RLC L CB05 


b) Rotagao para a esquerda atraves do “CARRY” 

Substitua na rotina anterior a instrugao RLC por RL C. Pode- 
se constatar que, diferentemente do caso anterior, quando o 
“CARRY” e igual a um, o valor em retorno e tao-somente o dobro 
do valor original, subtraido de 256. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 
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RL A CB 17 
RL B CB 10 
RL C CB 11 
RL D CB 12 
RL E CB 13 
RL H CB 14 
RL L CB 15 

c) Rotagao circular para a direita 

Suponhamos que o registrador C contem dois, antes da RRC C. 
Apos a sua implementagao, ele contera um; ou seja, ele foi dividido 
por dois. Contudo, isto so ocorre quando o valor presente no 
registrador for par e maior ou igual a 2. 

B7 B6 B5 B4 B3 B2 B1 B0 
antes 0 0 0 0 0 0 1 0 

depois 0 0 000001 

Para comprovar as consideragoes que acabamos de fazer, e 
testar o que ocorre quando o valor for impar ou menor do que 2, 
entre com a seguinte rotina: 


30000 

0600 

LD B,0 

30002 

0E00 

L D C0 

30004 

CB09 

RRC C 

30006 

3 in. 00 

LD A, 0 

30008 

SF 

ADC A,A 

30009 

3231-75 

LD (3001 

30012 

C9 

RET 


Utilize o mesmo programa dado no primeiro exercicio. 
Constata-se que, se o valor presente em C for nulo, o resultado 
e igualmente nulo, e o “CARRY” e zero. Se o valor for impar, 
“CARRY” e igual a um, e o valor em retorno e o inicial somado a 
255, dividido por dois. Portanto, se o registrador C for carregado 
com 255, apos RRC C, teremos 255. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 

RRC A CB0F 
RRC B CB08 
RRC C CB09 
RRC D CB0A 
RRC E CB0B 
RRC H CB0C 
RRC L CB0D 
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d) Rotagao para a direita atraves do “CARRY”. 

Substitua na rotina anterior a instrugao RRC C por RC C. 
Pode-se constatar que a unica diferenga reside no tratamento que 
recebem os valores impares. Aqui, o valor em retorno sera o valor 
contido no registrador C, subtraido de urn, dividido por dois. 
Portanto, se o registrador C for carregado com 255, o valor em 

retorno sera 127. . 

A tabela abaixo fornece o codigo em HEX destas mstrugoes. 

RR A CB IF 
RR B CB 18 
RR C CB 19 
RR D CB 1A 
RR E CB IB 
RR H CB 1C 
RR L CB ID 

A rotina abaixo utiliza este tipo de instrugao para converter 
numeros decimais em hexadecimais, no intervalo entre ® e 255. 


30000 

3E00 

LD A 

,0 

30002 

F5 

PUSH 

AP 

30003 

E6F0 

AND 

240 

30005 

IF 

RRA 


30006 

IF 

RRA 


30007 

IF 

RRA 


30008 

IF 

RRA 

A, 2' 

30009 

C61C 

ADD 

3001.1. 

D7 

R8T 

10H 

3001.2 

F1 

POP 

AF 

3001.3 

E60F 

AND 

1.5 

30015 

C61C 

ADD 

A * 2 

30017 

D7 

RST 

10H 

30018 

C9 

RET 



Estude cuidadosamente cada instrugao, procurando entender o 
que ela esta realizando. O programa abaixo permite a voce variar o 
decimal. 

10 INPUT X 
20 POKE 30001.X 
30 RAND USR 30000 
40 PRINT 
50 GOTO 10 
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II —- Instrugoes de DESLOCAMENTO (SHIFT). 

Nao iremos estudar todos os tipos de deslocamento. Contudo, 
explicaremos, atraves de exercicios, certas operagoes de SHIFT. 

a) Deslocamento aritmetico para a esquerda 

Vamos supor que desejamos efetuar um deslocamento aritme¬ 
tico para a esquerda do registrador C, que contem o valor 1. 

B7 B6 B5 B4 B3 B2 B1 B0 
antes: 00000001 

depois: 00000 0 10 

Apos SLA (SHIFT LEFT ARITHMETIC), o valor presente 
em C foi duplicado, e o “CARRY” ficou igual a zero; isto e, o valor 
presente no BIT 7 e transferido para o “CARRY FLAG”, e o BIT 0 
foi zerado. 

A rotina abaixo permite testar este tipo de instrugao. 


30000 


30004 

30006 

30008 

30009 
3001.2 


0600 

0E00 

CB21 

3E00 

8F 

323F7S 

C9 


LD B.,0 

LD C,0 

SLA C 

L D A ? 0 

ADC A,A 

LD (30015),A 

RET 


O programa dado no primeiro exercicio de rotagao, permite variar o 
valor presente em C e controlar o “CARRY FLAG”. 

Se este valor for superior a 127, o resultado de SLA C sera o 
dobro do valor presente em C, subtraido de 256, e o “CARRY 
FLAG” sera ajustado, isto e, igual a um. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 


SLA A CB 27 
SLA B CB 20 
SLA C CB 21 
SLA D CB 22 
SLA E CB 23 
SLA H CB 24 
SLA L CB 25 


b) Deslocamento aritmetico para a direita 

Para testar esta instrugao, entre com a rotina dada no exercicio 
anterior, substituindo a instrugao SLA C por SRA C. 

Pode-se constatar que: 
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i) para valores pares ate 126, o resultado em retorno e o valor 
presente em C, dividido por dois. O BIT 7 nao e alterado, e o 
valor do BIT 0 vai para o “CARRY”. Por exemplo, se C for 
carregado com 120. teremos: 



B7 

B6 

B5 

B4 

B3 

B2 

B1 

B0 


antes: 

0 

1 

1 

1 

1 

0 

0 

0 

= 120 

depois: 

0 

0 

1 

1 

1 

1 

0 

0 

= 60 

t 


ii) para valores pares maiores do que 126, o resultado sera o valor 
contido em C, dividido por dois, somado a 128. O “CARRY 
FLAG” e reajustado, ou seja, igual a zero. 


B7 B6 B5 • B4 B3 B2 B1 B0 
antes: 1 0 0 0 0 0 0 0 

depois: 1 1000000 

Em outras palavras, nao ha alteragao no valor do BIT 7, e o 
valor presente no BIT 0 e copiado pelo “CARRY FLAG”; 
iii) para valores impares ate 127, o resultado da instrugao SRA C 
sera o valor contido em C, subtraido de um, dividido por dois; 
IV) para valores impares superiores a 127, o resultado sera o valor 
contido em C, subtraido de um, dividido por dois, somado a 128. 

Em suma, em todos os casos, o BIT 7 e conservado, o 
“CARRY FLAG” copia o BIT 0, e ha um deslocamento para a 
direita. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 

SRA A CB 2F 
SRA B CB 28 
SRA C CB 29 
SRA D CB 2A 
SRA E CB 2B 
SRA H CB 2C 
SRA L CB 2D 


A tabela abaixo fornece o codigo em HEX destas instrugoes. 

SRL A CB 3F 
SRL B CB 38 
SRL C CB 39 
SRL D CB3A 
SRL E CB 3B 
SRL H CB 3C 
SRL L CB 3D 

EXERCICIOS 

1) Escreva uma rotina que converta numeros decimais em hexadeci- 
mais, no inter valo, entre 0 e 65535. 

2) Escreva uma rotina que permita encontrar o quadrado de um 
numero dado. 


c) Deslocamento logico para a direita 

Para testar esta instrugao, utilize a mesma rotina, substituindo 
a instru$ao SRA C por SRL C. O programa em BASIC e o mesmo. 

Pode-se verificar que se o numero for par, ele sera dividido por 
dois. Se for impar, sera subtraido de um e, em seguida, dividido por 
dois. Apenas neste caso, o “CARRY FLAG” sera igual a um. 

Portanto, o BIT 7 sera reajustado e o BIT 0 copiado pelo 
“CARRY FLAG”. Todos os conteudos serao alterados um BIT 
para a direita. 
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CAPITULO VIII 

GRUPO DE MANIPULAQAO DE BIT 


Neste ultimo capitulo, desejamos indicar a possibilidade de se 
manipular diretamente os BITs. Podemos dividir este grupo em tres 
partes, de acordo com o tipo de manipula$ao envolvida. 
a) Ativagao do BIT — as instrugoes sao da forma SET x, y, onde x 
representa o numero do BIT envolvido (portanto, varia entre 0 e 7), 
e y esta no lugar, ou de urn registrador, simples ou indexado (neste 
caso, o registrador esta apontando para o conteudo de uma 
localidade na memoria), ou do conteudo de uma localidade na 
memoria. Por exemplo, a instru?ao SET 6,A resulta na ativagao do 
BIT 6 do acumulador; isto e, apos SET 6,A o BIT 6 do acumulador 
sera um. 

A rotina abaixo permite inverter todos os caracteres na tela que 
estao no intervalo entre 0 e 63 atraves da ativa?ao do BIT 7 do 
acumulador. 

30000 2A0C40 LD HL ? <16396) 

30003 061.6 LD B, 22 

30005 23 INC HI- 

30006 7E LD A., (HL.) 

30007 F'E-76 CP IIS 

30009 2805 JR Z,5 
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SET 7,A 
JR -11 
L..D (HL) A 
DJNZ -14 
RET 


Escreva um programa em BASIC que utilize a rotina acima. 

A tabela abaixo fornece o codigo em HEX destas instrugoes. 

SET 0, A CBC7 SET 1,A CB CF SET 2,A CB D7 SET 3,A C,B DF 
SET 0,B CB C0 SET 1,B CB C8 SET2,B CB D0 SET3,B CB D8 

SET 0,C CB Cl SET 1,C CB C9 SET 2,C CBD1 SET 3,C CBD9 

SET 0,D CB C2 SET 1,D CB CA SET 2,D CB D2 SET 3,D CB DA 

SET 0E CB C3 SET 1,E CB CB SET2,E CB D3 SET3,E CB DB 

SET 0,H CBC4 SET 1 ,H CB CC SET2.H CB D4 SET3,H CB DC 
SET 0,L CBC5 SET EL CB CD SET2JL CB D5 SET3,L CB DD 

SET 4,A CB E7 SET 5,A CB EFSET 6,A CB F7 SET 7,A CB FF 
SET 4,B CB E0 SET 5,B CB E8 SET 6,B CB F0 SET 7,B CB F8 

SET 4,C CB El SET 5,C CB E9 SET 6,C CB FI SET 7,C CB F9 

SET 4,D CB E2 SET 5,D CB EA SET 6,D CB F2 SET 7,D CB FA 

SET 4,E CB E3 SET 5,E CB EB SET 6,E CB F3 SET 7,E CB FB 

SET 4,H CB E4 SET 5,H CB EC SET 6,H CB F4 SET 7,H CB FC 

SET 4,L CB E5 SET 5,L CB ED SET 6,L CB F5 SET 7,L CB FD 

b) Restaura?ao do BIT — semelhante ao anterior, diferindo no fato de o 
BIT indicado pela instrugao ser restaurado, ou seja, zerado. 

A rotina abaixo permite inverter todos os caracteres na tela que 
possuam codigo superior a 127. 


30000 

2 A 0 C A 0 

LD HU <16 

30003 

0 616 

L b c) i 2 2 

300 05 

23 

INC HL 

30006 

/• E 

LD A : . (HL) 

30007 

.Ft 7 6 

CP 1T8 

30009 

2305 

JR Z,5 

30011 

CBBF 

RE 3 7,A 

30013 

-1 

/ / 

LD (HL),A 

30014 

.151-5 

JR -11 

30016 

77 

LD (HL > A 

30017 

101- 2 

DJNZ -14 

300 J 9 

C9 

RET 
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A tabela abaixo fornece em HEX o codigo destas instrugoes. 

RES 0,A CB87 RES 1,A CB8F RES 2,A CB97 RES 3,A CB9F 

RES 0,B CB80 RES 1,B CB88 RES 2,B CB90- RES 3,B CB98 

RES 0,C CB81 RES 1,C CB89 RES 2,C CB91 RES 3,C CB99 

RES 0,D CB82 RES 1,D CB8A RES 2,D CB92 RES 3,D CB9A 

RES 0,E CB83 RES 1,E CB8B RES 2,E CB93 RES 3,E CB9B 

RES 0,H CB84 RES 1,H CB8C RES 2,H CB94 RES 3,H CB9C 

RES 0,L CB85 RES 1,L CB8D RES 2,L CB95 RES 3,L CB9D 

RES 4,A CBA7 RES 5,A CBAF RES 6,A CBB7 RES 7,A CBBF 

RES 4,B CBA0 RES 5,B CBA8 RES 6,B CBB0 RES 7,B CBB8 

RES 4,C CBA1 RES 5,C CBA9 RES 6,C CBB1 RES 7,C CBB9 

RES 4,D CBA2 RES 5,D CBAARES 6,D CBB2 RES 7,D CBBA 

RES 4,E CBA3 RES 5,E CBAB RES 6,E CBB3 RES 7,E CBBB 

RES 4,H CBA4 RES 5,H CBACRES 6,H CBB4 RES 7,H CBBC 

RES 4,L CBA5 RES 5,L CBAD RES 6,L CBB5 RES 7,L CBBD 

c) Teste do BIT — as instrugoes sao da forma BIT x,y onde x 
representa o numero do BIT (intervalo entre 0 e 7), e y pode ser um 
registrador, simples ou indexado (neste caso, o registrador aponta 
para o conteudo de uma localidade na memoria), ou o conteudo de 
uma localidade na memoria. Por exemplo, BIT 0, A testa o estado 
do BIT 0 do acumulador. Se ele for zero, entao o “ZERO FLAG” 
sera ativado; caso contrario, sera restaurado. 

A rotina abaixo permite converter numeros decimais em 
binarios, no intervalo entre 0 e 255, atraves do teste do BIT 7 do 
registrador C. 


30000 

0E00 

LD C,0 

30082 

0608 

LD B 8 

30004 

CB79 

BIT 7,C 

30006 

3 El C 

LD A,28 

30005 

2801 

JR Z,1 

30010 

3C 

INC A 

30011 

D 7 

RSI 10H 

30012 

CB 11 

RL. C 

30014 

101“ 4 

DJNZ -12 

30016 

C9 

RET 


Escreva um programa em BASIC que permita variar o numero 
em decimal. 
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A tabela abaixo fornece em HEX o codigo destas instru<?6es. 

RTT A CB 47 BIT 1,A CB 4F BIT 2,A CB 57 BIT 3,A CB 5F 
IS SbS « bit l.B CB 48 BIT 2 B CB 50 BIT 3.B CB 58 
RTT 0 C CB 41 BIT 1,C CB 49 BIT 2,C CB 51 BIT 3,C CB 59 
BIT 0,D CB 42 BIT 1,D CB 4A BIT 2,D CB 52 BIT 3,D CB 5A 
BIT 0 E CB 43 BIT 1,E CB 4B BIT 2,E CB 53 BIT 3,E CB 5B 
IS 0 .H c! 44 in l’,H CB 4C BIT 2 ,H CB 54 BIT 3,H CB 5C 
BIT 0,L CB 45 BIT 1,L CB 4D BIT 2,L CB 55 BIT 3,L CB 5D 

BTT 4 A CB 67 BIT 5,A CB 6F BIT 6,A CB 77 BIT 7,A CB 7F 
BIT 4 B CB 60 BIT 5,B CB 68 BIT 6,B CB 70 BIT 7,B CB 78 
BIT AC CB 61 BIT 5,C CB 69 BIT 6,C CB 71 BIT 7,C CB 79 
BIT A,T> CB 62 BIT 5,D CB 6A BIT 6,D CB 72 BIT 7,D CB 
BIT 4,E CB 63 BIT 5,E CB 6B BIT 6,E CB 73 BIT 7,E CB 7B 
BIT 4,H CB 64 BIT 5,H CB 6C BIT 6,H CB 74 BIT 7,H CB 7 
BIT 4,L CB 65 BIT 5,L CB 6D BIT 6,L CB 75 BIT 7,L CB 7D 

Exercicios: 

1) Escrevauma rotina que converta numeros decimals em binarios no 

intervalo entre 0 e 65535. , 

2) Escreva uma rotina que inverta a tela, nao importando se os 

caracteres ja estao invertidos ou nao. 
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EPILOGO 

Digite a rotina abaixo. 


30000 

"S u'i i 

00 

ij\ i2l 

HOF 

isj |i V 


o rj k:) j. 

30802 

tC J 

3E08 

1 1 i 

LD 

A ; 3 8 

3 0 0 0 4 

">; n q ' ) • 7 

LD 

i. 30098 > A 

3 0 Q @ 7 

3A3448 

LD 

A ( 16436 ) 

300:1.0 

329875 

LD 

(30104) A 

300.13 

2A0C40 

LD 

Hi... ? (16396) 

30016 

118588 

LD 

DE.181 

3001? 

19 

ADD 

HL D E 

30020 

3 6 3 4 

LD 

<HL),52 

38022 

223875 

LD 

(30000),HL 

30025 

3E08 

LD 

A0 

30027 

8638 

LD 

B48 

38029 

8EFF 

LD 

p ■ ■» , ;i in-1::* 

\i.* ;i a'.i v.« 

30831 

00 

DEC 

c 

30032 

20FD 

JR 

NZ -3 

30034 

10F9 

DJN 

Z ™7 

30036 

COBB@2 

CAL 

,L 699 

30839 

4 ^ 

LD 

B.,H 

30840 

40 

LD 

C I... 

38041 

9P 

Am i»V 

INC 

1... 

30042 

28F8 

JR 

Z ? ~8 

38844 

COB007 

CAL 

L 1981 

30047 

4E 

L.D 

C,< HL) 

38043 

79 

LD 

A ;t L 

38049 

2A3075 

LD 

HL,(30000) 

38052 

FE21 

CP 

33 

30054 

280E 

JR 

Z 1 4 

30856 

i- F 2 2 

r hn A** Am 

CP 

34 

30058 

2814 

JR 

Z,20 

30060 

FE23 

CP 

35 

3 0 0 6 2. 

2815 

JR 

Z, 21 

38064 

FE24 

CP 

36 

38066 

2807 

JR 

Z,7 

30863 

180E 

JR 

-34 

38070 

3600 

LD 

(HL), 0 

30072 

2B 

DEC 

HL 

38073 

1810 

JR 

16 
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30075 

3600 

LD (HL) 0 

30077 

23 

INC HL 

30078 

1808 

JR 11 

30080 

112100 

LD DE,33 

30083 

1803 

JR 3 

30085 

119 F FF 

LD DE, -■•33 

30038 

3660 

i... i j i H L ) ; i 9 

30090 

,1 Y 

ADD HLDE 

30091 

7E 

LD A :t (HL ) 

30092 

F EBB 

CP 0 

30094 

C0 

RET NZ 

30895 

C'j X ** 

LD (HL),20 

38897 

61“, 0 0 

L D A :»0 

30099 

6 C 

INC A 

3 018 8 

329275 

LD (30098);. A 

3 81 8 3 

3E00 

LD A 0 

30185 

✓ “‘1 
/ 

LD B A 

30106 

F6DF 

OR 223 

30108 

EE OF 

XOR 223 

30110 

CB07 

RLC A 

30112 

CB07 

RLC A 

30114 

CB08 

RRC B 

3 0116 

A 8 

XOR 8 

30117 

329875 

LD (30104),A 

30.1.20 

22CF75 

LD (30159),HI 

30123 

FEC0 

CP 192 

30125 

3803 

JR C •. 3 

30127 

28 

DEC HL. 

30128 

1815 

JR 21 

38130 

FE80 

CP 128 

30132 

3606 

JR C, 6 

30134 

112100 

LD DE,33 

30.1.37 

19 

ADD HL,DE 

30138 

1808 

JR 11 

30148 

FE40 

CP 64 

30142 

3606 

JR C, 6 

30144 

11DFFF 

LD DE,-33 

30147 

19 

ADD HL,DE 

30148 

1801 

JR 1 

30150 

JU W 

INC HL 


30151 

3697 

LD (HL) 

30153 

2ACF75 

LD HL,( 

30156 

C34675 

JP 3002 

30159 

00 

NOP 

30160 

00 

NOP 


Para chama-la, digite RAND USR 30002. Ela deve ser cercada 
com o seguinte programa em BASIC (modo SLOW): 

10 LET S$ =“32 espagos no modo grafico” 

20 LET LS = “modo grafico 5,30 espa?os, modo grafico 8” 

30 PRINT S$ 

40 FOR T =1 TO 9 
50 PRINT L$ 

60 NEXT T 
70 PRINT S$ 

80 RAND USR 30002 
90 PRINT PEEK 30098 

O que ocorre? Descubra investigando a rotina acima. Dica: as teclas 
5, 6, 7 e 8 controlam certas ocorrencias na tela. (Caso voce nao 
consiga entender, leia o Apendice 6). 
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APENDICE 1 

TABELA DE CARACTERES 


0 

27 . 

54 

Q 

145 

m 

172 

B 

1 * 

28 0 

55 

R 

146 

m 

173 

IS 

a * 

29 1 

56 

S 

147 

m 

174 

B 

3 M 

30 2 

57 

T 

146 

B 

175 

m 

4- a 

31 3 

58 

U 

149 

B 

176 

ns 

129 

UKB 

-5 1 

32 4- 

59 

M 

isb 

S3 

SSm 

177 

B 

6 / 

33 5 

50 

U 

151 

B 

178 

IS 

7 P 

34- 6 

51 

X 

152 

m 

179 

m 

8 §g 

35 7 

82 

V 

153 

a 

180 

m 


36 8 

53 

Z 

154 

as 

181 

m 

10 w* 

37 9 

128 

w 

155 

B 

132 



38 fl 

129 

A 

156 

IS 

183 

S3 

ia £ 

39 B 

130 

a. 

157 

0 

184 

SI 

is $. 

4.0 C 

131 

» 

15© 

0 

135 

3 

14- : 

41 0 

132 


159 

S 

186 

IS 

15 7 

42 E 

133 

1 

160 

B 

187 

as 

16 C 

43 F 

134 

** 

161 

@ 

188 

25 

17 X 

44 G 

135 

■ 

162 

S 

109 

s 

IS > 

45 H 

136 

m 

163 

B 

19© 

ss 

1-3 < 

46 I 

137 

m 

164 

B 

191 

H 

20 = 

47 D 

138 

M 

165 

B 



21 + 

43 K 

139 

m 

IS© 

S 



__ 

fS, tS. 

49 L 

140 

s 

157 S 



23 * 

50 M 

141 

m 

168 

B 



24* / 

51 N 

142 

m 

189 

S 



25 ; 

52 O 

143 S 

170 

S 



26 .. 

53 P 

144 

S3 

171 

B 
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APENDICE 2 

TABELA DE CONVERSAO DE DECIMAL EM HEX 


8 

-08 

33 

=26 

76 

=4C 

114 - 

■ 7 n 

* / A*,. 

152= 

■* V 3 

190= 

=BE 

'"}'“} 0 - 
A*>. A'.. In* *' 

*= E 4 

:l 

a 81 

39 

~ 9 7. 

Am / 

77 

=40 

115= 

“73 

153= 

= 99 

191 = 

=13 F 

229 = 

=E5 

V 

Am 

==02 

40 

=28 

78 

=4E 

116- 

=74 

154= 

=9 A 

192= 

=C 0 

230= 

*=E 6 

W 

==03 

41 

=29 

79 

=4F 

117=75 

155= 

=98 

193= 

*=C 1 

231 = 

-E7 

4 

==04 

42 

=2A 

88 

=50 

118= 

=76 

156= 

■Ml 

194= 

*=C 2 

n '/ ■;:> - 

Am W Am 

=E 8 

5 

==05 

43 

== 2 B 

31 

=51 

119= 

" / / 

157= 

= 90 

195= 

=C3 

OT^ 

A*» W 

=E9 

6 

==*06 

4 ■‘t 

= 2 C 

82 

1 J 

W A.. 

120 = 

=73 

158= 

= vE 

196= 

*=C4 

0^4 = 

A.. v..‘ T 

=EA 

7 

= 07 

45 

=20 

33 

.... *7 

121 = 

=79 

159= 

:: F 

197= 

-C5 

j-} 71 ::- 
2 o a j - 

=EB 

3 

==08 

46 

r=: 2 E 

84 

=54 

1 OO’s 

• 1 * A»♦ A*« 

=7 A 

;i 60= 

= A0 

198= 

*= L 9 

2?36= 

=EC 

9 

=89 

4 /" 

= 21 " 

35 

=55 

123= 

=78 

161 = 

=A 1 

19 y = 

=C7 

-T-J 
Am W / 

-ED 

10 

== 0 rt 

4 3 

=30 

86 

=56 

124= 

=7C 

162= 

™ A 2 

200 = 

*= (- 3 

O A - 

A#, V *. 1 

=EE 

:l. 1 

== 8 B 

49 

-31 

O *7 
O / 

=57 

125= 

=70 

163= 

= A3 

201 = 

=C9 

239“ 

=EF 

12 

== 0 C 

50 

**** A * J 

W/ Am 

88 

=58 

126= 

=7E 

164 = 

•* A 4 

202 = 

=CA 

240“ 

=F 0 

13 

=00 

51 

-33 

39 

=59 

127= 

=7F 

165= 

=A5 

203= 

=CI3 

2 41 “ 

=F 1 

14 

= 8 e: 

52 

-- 3 

90 

=5A 

128= 

=80 

166= 

=A 6 

204 = 

=CC 

f ‘\ .* •*-i.. 

**:. A t a*:. - 

=F 2 

IS 

= 01 " 

5 -.5 

===35 

91 

=5B 

129= 

=81 

167= 

=A7 

205= 

=CD 

243“ 

=F3 

16 

= 10 

5 4 

= 36 

92 

=5C 

138= 

=82 

168= 

= A 8 

206= 

=CE 

2 4 4 - 

= 8 9 

17 

=11 

5 5 

= 37 

93 

=5D 

13 . 1 . = 

=8 3 

169= 

=A9 

207= 

=CF 

245“ 

=F5 

13 

= 12 

5 6 

=38 

94 

=5E 

132= 

= 84 

170= 

=AA 

208= 

=00 

246= 

=F 6 

19 

= 13 

57* 

= 39 

95 

=5F 

133= 

=85 

171 = 

=A 8 

209= 

=D 1 

247= 

=F7 

28 

= 14 

58 

=3A 

96 

=60 

134= 

** 8 6 

172= 

2 AC 

210 = 

=02 

248= 

=F 8 

91 ; 

A*.. .1. 

== 15 

59* 

=38 

97 

=61 

135= 

=37 

173= 

=A0 

211 = 

=D3 

249= 

=F9 

0 o , 

Am A*» 

= 16 

60 
61 

==3C 

98 

=62 

136= 

=88 

1 7 £ t : 

=AE 

9 1 9: 

A.. .1. A.. 

=D4 

250= 

=FA 

9 7; 

Am *.J 

= 17 

=30 

99 

=63 

13,7= 

=89 

175= 

=AF 

213= 

=05 

251 = 

=FB 

24 

== 13 

62 

= 3E 

100 

=64 

133= 

= 8 A 

j, / h - 

=80 

214= 

=06 

n .. 

A«4 \tr At* 

=FC 

25 

= 19 

63 

= 3F 

101 

=65 

139= 

=88 

177= 

=81 

215= 

=07 

253= 

=F0 

26 

== 1 A 

64* 

=40 102 = 

=66 

140= 

= 8 C 

178= 

*=82 

216= 

=08 

254= 

=FE 

n 

A.. / 

= 18 

65= 

=41 

103 

==6 7 

141 = 

=80 

j. 7 9 s 

=83 

217= 

=09 

9’=: 5= 

Am \t» 

=FF 

r > 0 
c; 

= 1 C 

66 = 

=42 

104 

=68 

142= 

= 8 E 

180= 

*** B 4 

0*1 p - 

A«> M» 

=DA 



n a ; 

A.. / 

= 10 

67= 

=43 

105 

=69 

143= 

=9F 

131 = 

=85 

219= 

= 0 B 



38 

= 1E 

68 = 

=44 

106 

=6 A 

144= 

=90 

182= 

*= 86 . 

220 = 

=DC 



31* 

= IF 

69= 

=45 

107 

=68 

145= 

=91 

133= 

=8 7 

9 9 1 

Am A#* Jf 

=00 



32 

=20 

70= 

=46 

103 

= 6 C 

146=92 

184= 

= 88 

'*) O H - 

m 

At* A«» 

=DE 



33* 

=21 

71 = 

=47 

109 

=60 

147= 

=93 

185= 

=89 

223=* 

-OF 



34 

.... O **j 

-** A\. A*.. 

•70- 

m Am 

=48 

110 

= 6 E 

148= 

“94 

186= 

**B A 

224 = 

=E0 



35* 

=23 

73= 

=49 

111 

= 6 F 

149= 

- o 

. w 

187= 

=813 

O O r ' : i s: 

At* A** w 

=E1 



36* 

=24 

74= 

=4A 

112 

=70 

150= 

= 96 

188= 

=BC 

226- 

=E2 



37= 

=25 

75= 

=4B 

113 

=71 

151 =* 

= 97 

189= 

= 130 

0 O 7 s: 

Am A«i / 

*E3 
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APENDICE 3: VARIAVEIS DO SISTEMA 


Enderego 

16384 

16385 


16386 

16388 

16390 

16391 

16393 

16394 
16396 
16398 
16400 
16402 
16404 
16406 
16408 
16410 
16412 

16414 

16415 

6417 

84 


Fungao 

(4 000) Codigo de erro. 

(4 001) “Sinalizadores” 

Bit 0 - Controla espago. 

Bit 1 - Controla impressora. 

Bit 2- Controla modo de funcionamento: K, L, 

F ou G. 

Bit 6 - Controla parametros. 

Bit 7 - Controla sintaxe. 

(4 002) Aponta para o topo do Stack apos uma 

(4 003) Instrug2o de Gosub. 

(4 004) O topo do RAM existente ou 

(4005) fixado pelo usuario , 

(4 006) Especifica o cursor que esta sendo usado. 

(4 007) Numero da linha que esta sendo executada. 

(4009? 0 P onto iniciai do RAM que 8 uardado 

1 em tape. A partir de um comando “Save”. 

(4 00A) A linha de BASIC onde esta o cursor. 

(4 00B) . . 

(4 00C) Ponteiro para o arquivo de imagem. 

(4 00D) . , , „ D . . At „ 

(4 00E) Enderego que indica o local para rrmt At . 

(400F) , . ... 

(4010) Ppnteiro para a area de van aveis. 

(4011) 

(4012) Enderego da variavel sendo executada dentro d 

(4013) area de programa. 

(4014) Ponteiro para area de trabalho. 

(4015) . , • 

(4016) Ponteiro que procura uma linha dentro oa 

(4017) Area de programa ou da area de trabalho. 

(4018) Enderego do erro de sintaxe. 

(4019) 

(401 A) Ponteiro que aponta o imcio 
(40IB) do “stack” de calculo. 

(401C) Ponteiro que aponta para o 
(401D) final do “stack” de calculo. 

(40IE) Usado pelo calculador em ponto flutuante. 
(401F) Enderego que aponta para a area onde 
(4020) serao feitos os calculos. 

(4021) Nao e usado. 


16418 

16419 

16421 

16423 

16424 

16425 

16427 

16429 


16430 

16432 

(4031) 

16434 

16436 

16438 

16440 

16441 

16443 


16444 

16477 

16507 


(4022) 

(4023) 

(4024) 

(4025) 

(4026) 

(4027) 

(4028) 

(4029) 

(402A) 

(402B) 

(402C) 

(402D) 


(402E) 

(402F) 

(4030) 

(4032) 

(4033) 

(4034) 

(4035) 

(4036) 

(4037) 

(4038) 

(4039) 

(403A) 

(4030) 


(403C) 

(405D) 

(407B) 

(407c) 


Numero de linhas na parte inferior da tela. 

A linha a ser chamada automaticamente na 
listagem. 

Valor da ultima tecla pressiortada. 

Estado de nao oscilagao do teclado. 

Numeros de linhas acima ou abaixo da imagem. 
Enderego da proxima linha de BASIC a ser 
interpretada. 

Numero da linha para a qual uma 
instrugao “Cont” salta. 

“Sinalizadores”: Bit 0-0 indica variavel indexada. 
Bit 1 - 0 indica que uma variavel dada existe. 

Bit 5 - 1 indica instrugao Input em funcionamento. 
Bit 6-1 indica que o comando Input espera um 
valor numerico. 

Extensao de uma string ou de uma linha deBASIC, 
Ponteiro para tabela de sintaxe. 

O valor originario colocado na fungao RND. 

O contador de quadros gerados na tela. 

Coordenada x do ultimo ponto colocado em tela. 
Coordenada Y do ultimo ponto colocado na tela. 
Contador para a posigao da Impressora. 

Numero da linha e da coluna, respectivamente para 
o comando Print At. 

Sinalizadores: BIT 0-1 quando e 
pressionada uma tecla. 

BIT 6 - controla “SLOW’’/“FAST”. 

BIT 7 - controla “SLOW”/“FAST” durante exe- 
cugao de “COPY”; 0 quando no modo “FAST” 
Armazenamento da impressora 
Area da memoria que pode guardar ate seis 
numeros representados em ponto flutuante. 

Nao sao usados. 


A primeira listagem decorre do seguinte programa: 

10 For n=16384 TO 16507 

20 Print N; “ = Peek N, N -I- 1; “=”; Peek (N-i-1) 
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30 LET N = N -i- 1 
40 NEXT N 

A listage.m seguinte resulta do programa acima, substituindo-se a linha 
10 por 10 FOR N=l6509 TO 16608. 

Procure interpretar o conteudo dos endere^os em termos das variaveis 
do sistema. Use a segunda listagem para entender como e estruturada a 
area de programa. 


VARIAVEIS DO SISTEMA 


163&A 


255 

16385 


192 

16 3 & 6 

— 

n f ;:» 

Ati *»»< A*# 

16387 


127 

16338 

16339 
16390 


0 

128 

0 

16 391 

-- 

20 

16392 

16393 


0 

0 

16394 

-- 

40 

16395 

16 3 96 


0 

A** **if »*► 

16 3 9 7 

-- 

6 4 

16393 


209 

16399 


65 ; 

16400 


250 

16 401 


67 

16402 

::u 

250 

16 4 0 5 

:::: 

/ * J \* 

£> / 

16 4 0 4 


13 

16405 

- 

6 8 

16 4 06 

;:u 

171 

1640 7 

*••• 

6 4 

16403 

— 

167 

16409 


64 

16410 
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-- 
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00 
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- 
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16440 
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o 
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17 
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*» *-* 

192 
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- 

0 

16444 

SC 

0 

16445 

sc 

0 


16446 = 0 

16447 ~ 0 

16448 ~ 0 

16449 ~ 0 

16450 » 0 

16451 - 0 

16452 ~ 0 

16453 == 0 

16454 = 0 

16455 * 0 

16456 ~ 0 

16457 = 0 

16458 ••= 0 

16459 - 0 

16460 = 0 

16461 “ 0 

16462 « 0 

16463 « 0 

16464 ~ 0 

16465 = 0 

16466 - 0 

16467 = 0 

16468 - 0 

16469 = 0 

16470 a 0 

16471 = " 0 

16472 a 0 

16473 a 0 
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16475 a 0 


16477 


0 

164/8 

SC 

0 
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-* 

0 
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0 
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0 
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13 
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sc 
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sc 

0 
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sc 

0 
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0 
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— 
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zz 
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zz 
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zz 
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zz 
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zz 
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16494 
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16495 

zz 
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— 
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sc 
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sc 
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0 

16503 

zz 

0 

.16504 

zz 

0 

16505 

zz 

0 


16476 
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H 16507 a 0 


86 


Area do programa 


16509 


0 

16542 


41 

16576 

— 

90 

A*, / 
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0 

16577 


126 

16511 


27 

16544 

-- 

245 

16578 

SC 

129 

16512 


0 

16545 

zz 

51 

16579 

sc 

0 

16513 

z~ 

> •*>* c:* 

A-' Cr a 

16546 

zz 

25 

16580 

SC 

0 

16514 


51 

16547 

zz 

11 

16581 

SC 

0 

16515 

NH 

20 

16548 


0 

16582 


0 

16516 


no 

A,. / 

16549 

zz 

20 

16583 


17 

16517' 

MH 

34 

16550 

:z: 

0 

16584 

Mt* 

118 

16518 

ZZ 

•*y '? 
o x!) 

16551 

zz 

11 

16585 

4M4 

0 

30 

16519 

zz 

28 

16552 

zz 

26 

16586 

WM 

16520 


37 

16553 

zz 

211 

16587 


13 

16521 

zz 

126 

16554 

zz 

51 

16588 

zz 

0 

16522 

zz 

143 

16555 

^•-1 

26 

16589 


241 

16523 

JJ 

0 

16556 

>H< 

51 
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zz 

25 
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sc 
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ZZ 
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sc 
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sc 
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zz 
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16572 

sc 
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zz 
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zz 

20 

16574 

16575 

zz 
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APENDICE 4: CODIGO DE INSTRUgOES DO Z80A 




CB 

ED 

FD 

FDCB dis 

00 

NOP 

RLC B 




01 

LD BC, NN 

RLC C 




02 

LD(BC), A 

RLC D 




03 

INC BC 

RLC E 




04 

INC B 

RLC H 




05 

DEC B 

RLC L 




06 


RLC (HL) 



RLC (IY+ d) 

07 

RLCA 

RLC A 




08 

EXAF, AF’ 

RRC B 




09 


RRC C 


ADD IY, BC 


0A 

LD A, (BC) 

RRC D 




0B 

DEC BC 

RRC E 




0C 

INC C 

RRC H 




0D 

DEC C 

RRC L 




0E 

LD C, N 

RRC (HL) 



RRC (IY+d) 

0F 

RRCA 

RRC A 




10 

DJNZ dis 

RL B 




11 

LD DE, NN 

RL C 




12 

LD (DE), A 

RL D 




13 

INC DE 

RL E 




14 

INC D 

RL H 




15 

DEC D 

RL L 




16 

LDD, N 

RL (HL) 



RL (IY+d) 

17 

RLA 

RL A 




18 

JR dis 

RR B 




19 

ADD HL, DE 

RR C 


ADD IY, DE 


1A 

LD A, (DE) 

RR D 




IB 

DEC DE 

RR E 




1C 

INC E 

RR H 




ID 

DEC E 

RR L 




IE 

LD E, N 

RR (HL) 



RR (IY+dis) 

„ IF 

RRA 

RRA 




20 

JR NZ, dis 

SLA B 




21 

LD HL, NN 

SLA C 


LD IY, NN 


22 

LD (NN), HL 

SLA D 


LD(NN), IY 


23 

INC HL 

SLA E 


INC IY 


24 

INC H 

SLA H 




25 

DEC H 

SLA L 




26 

LD H, N 

SLA (HL) 



SLA (IY + dis) 

27 

DAA 

SLA A 







CB 

ED 

FD 

FDCB dis 

28 

JRZ, dis 

SRA B 




29 

ADD HL, HL 

SRA C 


ADD IY, IY 


2A 

LD HL, (NN) 

SRA D 


LD IY, (NN) ! 


2B 

DEC HL 

SRA E 


DEC IY 


2C 

INC L 

SRA H 




2D 

DEC L 

SRA L 




2E 

LD L, N 

SRA (HL) 



SRA (IY + dis) 

2F 

CPL 

SRA A 




30 

JR NC, dis 





31 

LD SP, NN 





32 

LD (NN), A 





33 

INC SP 





34 

INC (HL) 



INC (IY + dis) 


35 

DEC (HL) 



DEC (IY -i- dis) 

36 

LD(HL), N 



LD (IY -i- dis),N 

37 

SCF 





38 

JRC,dis 

SRL B 




39 

ADD HL,SP 

SRL C 


ADD IY, SP 


3A 

LD A, (NN) 

SRL D 




3B 

DEC SP 

SRL E 




3C 

INC A 

SRL H 




3D 

DEC A 

SRL L 




3E 

LD A,N 

SRL (HL) 



SRL (IY + dis) 

3F 

CCF 

SRL A 




40 

LD B,B 

BIT 0,B 

INB, (C) 



41 

LD B,C 

BIT 0, C 

OUT (C),B 



42 

LD B,D 

BIT 0,D 

SBC HL, BC 



43 

LD B,E 

BIT 0,E 

LD(NN),BC 



44 

LD B, H 

BIT 0, H 

NEG 



45 

LD B,L 

BIT 0,L 

RET N 



.46 

LD B, (HL) 

BIT 0, (HL) 

IM 0 

LD B, (IY + dis) 

BIT0,(IY -i-dis) 

47 

LD B,A 

BIT 0, A 

LD I,A 



48 

LD C,B 

BIT I,B 

IN C, (C) 



49 

LD C,C 

BIT1, C 

OUT (C),C 



4A 

LD C,D 

BIT 1, D 

ADC HL, BC 



4B 

LD C,E 

BIT 1, E 

LD BC, (NN) 



4C 

LD C, H 

BIT 1, H 




4D 

LD C,L 

BIT 1, L 

RET 2 



4E 

LD C, (HL) 

BIT 1, (HL) 


LDC,(IY + dis) 

BIT1,(IY + dis) 

4F 

LD C,A 

BIT 1, A 

LD R,A 



50 

LD D,B 

BIT 2,B 

IN D, (C) 



51 

LD D,C 

BIT 2,C 

OUT (C),D 




88 


89 






CB 

ED 

FD 

FDCB dis 

52 

LD D,D 

BIT 2,D 

SBC HL,DE 



53 

LD D,E 

BIT 2,E 

LD (NN),DE 



54 

LD D,H 

BIT 2,H 




55 

LD D,L 

BIT 2,L 




56 

LD D,(HL) 

BIT 2,(HL) 

IM 1 

LD D,(IY-i-dis) 

BIT 2,(IY+dis) 

57 

LD D,A 

BIT 2,A 

LD A, I 



58 

LD E,B 

BIT 3,B 

INE, (C) 



59 

LD E,G 

BIT 3,C 

OUT (C),E 



5A 

LD E,D 

BIT 3,D 

ADC HL,DE 



5B 

LD E,E 

BIT 3,E 

LD DE,(NN) 



5C 

f i ti J 

BIT 3,H 




5D 

LD E,L 

BIT 3,L 




5E 

LD E,(HL) 

BIT 3,(HL) 

IM 2 

LD E,(IY-i-dis) 

BIT 3, (IY+dis) 

5F 

LD E,A 

BIT 3,A 

LD A,R 



60 

LD H,B 

BIT 4,B 

IN H,(C) 



61 

LD H,C 

BIT 4,C 

OUT (C),H 



62 

LD H,D 

BIT 4,D 

SBC HL,HL 



63 

LD H,E 

BIT 4,E 

LD (NN),HL 



64 

LD H,H 

BIT 4,H 




65 

LD H,L 

BIT 4,L 



BIT 4,(IY+dis) 

66 

LD H,(HL) 

BIT 4,(HL) 


LD H,(IY+dis) 


67 

LD H,A 

BIT 4,A 

RRD 



68 

LD L,B 

BIT 5,B 

IN L,(C) 



69 

LD L,C 

BIT 5,C 

OUT (C),L 



6A 

LD L,D 

BIT 5,D 

ADC HL,HL 



6B 

LD L,E 

BIT 5,E 

LD DE,(NN) 



6C 

LD L, H 

BIT 5, H 




6D 


BIT 5, L 




6E 

LD L, (HL) 

BIT 5,(HL) 


LD L, (IY-i-dis) 

BIT 5, (IY-i-dis) 

6F 

LD L, A 

BIT 5, A 




70 

LD(HL), B 

BIT 6, B 


LD(IY+dis), B 


71 

LD(HL), C 

BIT 6,C 


LD(IY-i-dis), C 


72 

LD(HL), D 

BIT 6,D 


LD(IY+dis), D 


73 

LD(HL),E 

BIT 6,E 


LD(IY+dis), E 


74 

LD(HL), H 

BIT 6,H 


LD(lY+dis), H 


75 

LD(HL), L 

BIT 6,L 


LD(IY+dis), L 


76 

HALT 

BIT 6, (HL) 



BIT 6,(IY-i-dis) 

77 

LD(HL), A 

BIT 6,A 


LD(IY+dis), A 


78 

LD A, B 

BIT 7,B 




79 

LD A, C 

BIT 7,C 




7A 

LD A, D 

BIT 7,D 




|7B 

LD A,E 

BIT 7,E 





90 




CB 

ED 

FD 

FDCB dis 

7C 

LD A,H 

BIT 7,H 




7D 

LD A,L 

BIT 7,L 




7E 

LD A, (HL) 

BIT 7, (HL) 


LD A, (IY+dis) 

BIT 7, (IY+dis) 

7F 

LD A, A 

BIT 7,A 




80 

ADD A,B 

RES 0,B 




81 

ADD A,C 

RES 0,C 




82 

ADD A,D 

RES 0,D 




83 

ADD A,E 

RES 0,E 




84 

ADD A,H 

RES0,H 




85 

ADD A,L 

RES 0,L 




86 

ADD A, (HL) 

RES 0, (HL) 


ADDA,(IY+dis) 

RES 0, (IY+dis) 

87 

ADD A,A 

RES 0,A 




88 

ADC A,B 

RES 1,B 




89 

ADC A,C 

RES 1,C 




8A 

ADC A,D 

RES 1,D 




8B 

ADC A,E 

RES 1,E 




8C 

ADC A,H 

RES 1,H 




8D 

ADC A,L 

RES 1,L 




8E 

ADC A,(HL) 

RES 1 ,(HL) 


ADC A,(IY+dis) 

RES 1, (IYi-dis) 

8F 

ADC A,A 

RES 1,A 




90 

SUB B 

RES 2,B 




91 

SUB C 

RES 2,C 




92 

SUB D 

RES 2,D 




93 

SUB E 

RES 2,E 




94 

SUB H 

RES 2,H 




95 

SUB L 

RES 2,L 




96 

SUB (HL) 

RES 2,(HL) 


SUB (IY+dis) 

RES 2, (IY-i-dis) 

97 

SUB A 

RES 2,A 




98 

SBC A,B 

RES 3,B 




99 

SBC A,C 

RES 3,C 




9A 

SBC A, D 

RES 3,D 




9B 

SBC A,E 

RES 3,E 




9C 

SBC A, H 

REB S 3,H 




9D 

SBC A,L 

RES D,L 




9E 

SBC A, (HL) 

RES 3, (HL) 


SBC A, (IY+dis) 

RES 3, (IY+dis) 

9F 

SBC A,A 

RES 3,A 




A0 

AND B 

RES 4,B 

LDI 



A1 

AND C 

RES 4,C 

CPI 



A2 

AND D 

RES 4,D 

INI 



A3 

AND E 

RES 4,E 

OUTI 



A4 

AND H 

RES 4,H 




A5 

AND L 

RES 4,L 
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CB 

El 

A6 i 

\ND (HL) 

RES 4,(HL) 


A7 i 

AND A • 

RES 4,A 


as; 

KOR B 

RES 5,B 

^DD 

A9: 

KOR C 

RES 5,C 

:pd 

aa: 

KOR D 

RES 5,D 

[ND 

ab: 

•COR E 

RES 5,E 

HUT D 

ac: 

KOR H 

RES 5,H 


ad: 

KOR L 

3.ES 5,L 


|ae 

KOR (HL) 

RES 5,(HL) 


|AF 

XOR A 

RES 5,A 


B0 

OR B 

RES 6,B 

LDIR 

B1 

OR C 

RES 6,C 

CPIR 

B2 

OR D 

RES 6,D 

INIR 

B3 

OR E 

RES 6,E 

OTIR 

,B4 

OR H 

RES 6,H 


B5 

OR L 

RES 6,L 


B6 

OR (HL) 

RES 6,(HL) 


B7 

OR A 

RES 6,A 


B8 

CP B 

RES 7,B 

LDJDR 

B9 

CP C 

RES 7,C 

CPDR 

BA 

CP D 

RES 7,D 

INDR 

BB 

CP E 

RES 7,E 

OTDR 

BC 

CP H 

RES 7,H 


BD 

CP L 

RES 7,L 


BE 

CP(HL) 

RES 7,(HL) 


Bf 

CP A 

RES 7,A 


« 

IRET NZ 

SET Q B 


Cl 

POP BC 

SET 0,C 


C2 

JP NZ, NN 

SET0, D 


C3 

JP NN 

SET 0, E 



1CALL NZ,NN 

SET 0, H 


Ci 

PUSH BC 

SET 0, L 


C( 

ADD A. N 

SET 0, (HL) 


C 

RST 0A 

SET 0A 


Ci 

RET Z 

SET 1,B 


CS 

IRET 

SET 1,C 


Ci 

UP Z, NN 

SET 1,D 


Cl 

3 

SET 1,E 


C( 

2 CALL Z, NN 

SET 1,H 


CI 

1CALL NN 

SET 1,L 

i 

Cl 

2 ADC A,N 

SET 1,(HL) 

% 

Cl 

FIRST 8 

ISET 1,A 
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FD 

FDCB dis 

AND (IY+dis) I 

lis 4, (IY-i-dis) 

XOR (IY+dis) 

RES 5,(IY+dis) 

OR(IY+dis) 

RES 6,(IY+dis) 

CP(IY+dis) 

RES 7,(IY+dis) 


SET 0,(IY+dis) 


SET 1, (IY+dis) 




CB 

ED 

FD 

FDCB 

D0 

RET NC 

SET 2,B 




D1 

POP DE 

SET 2,C 




D2 

JP NC, NN 

SET 2,D 




D3 

OUT N,A 

SET 2,E 




D4 

CALL NC, NN 

SET 2,H 




D5 

PUSH DE 

SET 2,L 




D6 

SUB N 

SET 2, (HL) 



SET 2, (IY+dis) 

D7 

RST 16 

SET 2,A 




D8 

RET C 

SET 3,B 




D9 

EXX 

SET 3,C 




DA 

JP C, NN 

SET 3,D 




DB 

IN A,N 

SET 3,E 




DC 

CALL C, NN 

SET 3,H 




DD 


SET 3,L 




DE 

SBC A,N 

SET 3,(HL) 



SET 3 (IY+dis) 

DF 

RST 24 

SET 3,A 




E0 

RET PO 

SET 4,B 




El 

POP HL 

SET 4,C 

POP IY 



E2 

JP PO, NN 

SET 4,D 




E3 

EX(SP), HL 

SET 4,E 

EX(SP), IY 



E4 

CALL PO, NN 

SET 4,H 




E5 

PUSH HL 

SET 4,L 

PUSH IY 



E6 

AND N 

SET 4, (HL) 



SET 4, (IY+dis) 

E7 

RST 32 

SET 4,A 




E8 

RET PE 

SET 5,B 




E9 

JP (HL) 

SET 5,C 

JP(IY) 



EA 

JP PE, NN 

SET 5,D 




EB 

EX DE, HL 

SET 5,E 




EC 

CALL PE, NN 

SET 5,H 




ED 


SET 5,L 




EE 

XOR N 

SET 5,(HL) 


SET 5,(IY+dis) 


EF 

RST 40 

SET 5,A 




F0 

RET P 

SET 6,B 




FI 

POP AF 

SET 6,C 




F2 

JP P,NN 

SET 6,D 




F3 

DI 

SET 6,E 




F4 

CALL P,NN 

SET 6,H 




F5 

PUSH AF 

SET 6,L 




F6 

OR N 

SET 6,(HL) 


SET 6,(IY-i-dis) 


F7 

RST 48 

SET 6,A 




F8 

RET M 

SET 7,B 




F9 

LD SP,HL 

SET 7,C 


LD SP,IY 



93 





CB 

ED 

FD 

FDCBdis 

FA 

JP M, NN 

SET 7,D 




FB 

El 

SET 7,E 




FC 

CALL M,NN 

SET 7,H 




FD 


SET 7,L 




FE 

CP N 

SET 7,(HL) 


SET 7,(IY+dis) 


FF 

RST 56 

SET 7,A 





REGRAS PARA UTILIZACAO DA TABELA 

a) Para obter o codigo das instrugoes que utilizam o registrador 
indexado IX, basta trocar todas as ocorrencias de FD por DD. 

b) A tabela deve ser lida da coluna para a linha. Por exemplo, o codigo 
CBFA indica e instrugao que se encontfa na intersecgao entre a 
coluna CB e a linha FA, ou seja, SET 7,D. 

c) As instrugoes que se iniciam com FDCBdis tem quatro BYTEs - o 
quarto BYTE e encontrado na linha, e o terceiro depende do 
deslocamento desejado. Por exemplo, BIT 6,(IY+00) tem o codigo 
FDCB0076, onde 00 indica urn deslocamento nulo na representagao 
complemento de dois (oito BITs), e 76 indica que se trata do BIT 6. 

d) A tabela abaixo da uma indicagao aproximada (isto e, a maior dessas 
instrugoes vai estar no intervalo dado) de como encontrar o codigo 
de uma instrugao que nao utiliza registrador indexado. 


TIPO DE INSTRUGAO 
ROTACAO 
DESLOCAMENTO 
LOAD registrador, registrador 
ARITMETICAS 
LOGICAS 

MANIPULACAO DE BIT 
SALTO, CHAM AD AS, RETORNO 


LOCAL APROXIMADO EM HEX 


00 

20 

40 

80 

A0 

40 

C0 


IF (CB) 
3F (CB) 
7F 
9F 
B7 

FF (CB) 
FF 


APENDICE 5 — TABELA DE 
COMPLEMENTO DE DOIS (OITO BITs) 
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Apendice 6 


Voce so deve ler o que se segue se realmente procurou descobrir 

como funciona a rotina dada no epilogo. As observagoes abaixo irao 

ajuda-lo a compreende-la. 

Observances: 

a) os enderegos 30000 e 30001 guardam o enderego do arquivo de 
imagem; 

b) o enderego 30098 guarda o escore do jogo — cada vez que a.rotina 
passa por este ponto, ha urn incremento de urn, ao escore anterior - 

c) as instrugoes presentes entre 30013 e 30024 servem para colocar o 
caractere 0 na tela; 

d) no enderego 30104 e guardado o numero gerado pela variavel do 
srstema que conta os quadros colocados na tela — e um numero 
randomico; 

e) as instrugoes presentes entre 30025 e 30035 definem um “atraso” 
(DELAY) — quanto menor ele for, mais rapido sera o jogo — 
portanto, seria possivel definir um grau de dificuldade para jogo, 

atrayes da variagao do valor carregado no registrador B (enderego 
30028); 

f) entre enderego 30036 e 30048 e controlado o teclado — o valor do 
caractere. correspondente a teda acionada e guardado no acumula- 
dor (instrugao LD A,C: enderego 30048); 

g) se uma das teclas entre 5 e 8 for acionada, entao a posigao na tela, 

onde estava o caractere 0, sera limpada e definido o novo local de 
impressao deste carectere; 

h) se este novo local ja estiver ocupado, entao havera um retorno para 
o BASIC, e o valor presente no endereno 30098 definira o escore; 

i) as mstrunoes seguintes detectam se o caractere 0 ja atingiu a borda 
do tabuleiro, assim como imprimem aleatoriamente, numa das 
posinoes contiguas a localidade anteriormente ocupada por 0, o 
caractere 151; note como o lugar a ser impresso e definido atraves 
de instrugoes logicas de rotagao e de comparagao. 
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